- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
今天我需要一个简单的算法来检查一个数是否是 2 的幂。
算法需要:
ulong
值。我想出了这个简单的算法:
private bool IsPowerOfTwo(ulong number)
{
if (number == 0)
return false;
for (ulong power = 1; power > 0; power = power << 1)
{
// This for loop used shifting for powers of 2, meaning
// that the value will become 0 after the last shift
// (from binary 1000...0000 to 0000...0000) then, the 'for'
// loop will break out.
if (power == number)
return true;
if (power > number)
return false;
}
return false;
}
但后来我想:如何检查 log2 x 是否恰好是一个整数?当我检查 2^63+1 时,Math.Log()
由于四舍五入而恰好返回 63。所以我检查了 2 的 63 次方是否等于原始数,确实如此,因为计算是在 double
中完成的,而不是精确的数字。
private bool IsPowerOfTwo_2(ulong number)
{
double log = Math.Log(number, 2);
double pow = Math.Pow(2, Math.Round(log));
return pow == number;
}
对于给定的错误值,这返回了 true
:9223372036854775809
。
有没有更好的算法?
最佳答案
这个问题有一个简单的技巧:
bool IsPowerOfTwo(ulong x)
{
return (x & (x - 1)) == 0;
}
请注意,此函数将为 0
报告 true
,这不是 2
的幂。如果你想排除它,方法如下:
bool IsPowerOfTwo(ulong x)
{
return (x != 0) && ((x & (x - 1)) == 0);
}
首先是来自 MSDN 定义的按位二进制 & 运算符:
Binary & operators are predefined for the integral types and bool. For integral types, & computes the logical bitwise AND of its operands. For bool operands, & computes the logical AND of its operands; that is, the result is true if and only if both its operands are true.
现在让我们来看看这一切是如何发生的:
该函数返回 bool 值 (true/false) 并接受一个 unsigned long 类型的传入参数(在本例中为 x)。为了简单起见,让我们假设有人传递了值 4 并像这样调用函数:
bool b = IsPowerOfTwo(4)
现在我们将每次出现的 x 替换为 4:
return (4 != 0) && ((4 & (4-1)) == 0);
好吧,我们已经知道 4 != 0 的计算结果为真,到目前为止一切顺利。但是关于:
((4 & (4-1)) == 0)
这当然转化为:
((4 & 3) == 0)
但是 4&3
到底是什么?
4 的二进制表示是 100,3 的二进制表示是 011(记住 & 采用这些数字的二进制表示)。所以我们有:
100 = 4
011 = 3
想象一下,这些值就像初等加法一样叠加起来。 &
运算符表示如果两个值都等于 1,则结果为 1,否则为 0。所以 1 & 1 = 1
,1 & 0 = 0
、0 & 0 = 0
和 0 & 1 = 0
。所以我们算一下:
100
011
----
000
结果只是 0。所以我们回头看看我们的 return 语句现在翻译成什么:
return (4 != 0) && ((4 & 3) == 0);
现在翻译成:
return true && (0 == 0);
return true && true;
我们都知道 true && true
就是 true
,这表明对于我们的示例,4 是 2 的幂。
关于c# - 如何判断一个数是不是2的幂,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/600293/
我在编写数学函数时遇到了麻烦。它应该接受 3 个变量并像这样计算方程。 答案 = x(1 + y/100)^ z 我把它写成: public compute_cert (int years, doub
我正在开发一个计算器,以便更好地学习 Java。我编写了自己的代码来使用 BigDecimal 参数计算幂。截至目前,代码无法处理分数幂,例如 2^2.2。为了解决这个问题,我想在我的代码中实现指数恒
我正在寻找一种算法(或者更好的是,代码!)来生成幂,特别是奇数指数大于 1 的数字:三次幂、五次幂、七次幂等等。然后我想要的输出是 8, 27, 32, 125, 128, 216, 243, 343
在 Codewars 上找到这个。该函数接受两个参数 A 和 B,并返回 A^B 的最后一位。下面的代码通过了前两个测试用例,但不会通过下一个测试用例。 def last_digit(n1, n2):
像 2^(2%1) 这样的表达式在 GHCi 中不会进行类型检查,并且错误消息是神秘的。为什么这不起作用,我需要改变什么? 我无法转换为其他类型,我希望将其用于 27^(1%3) 等表达式。 最佳答案
我的二次幂没有达到应有的水平,所以我想也许我可以 #define 做点什么。 不幸的是,我在预处理器指令方面经验不足,我不知道如何做 for 循环之类的事情。我看了看: http://www.cplu
如何在 Math.net 中获得三角函数的幂? Expr x = Expr.Variable("x"); Expr g = (2 * x).Sinh().Pow(2); g.ToString()给出输
我正在尝试拟合这个渐近接近零(但从未达到它)的数据。 我相信最好的曲线是逆逻辑函数,但欢迎建议。关键是预期的衰减“S 曲线”形状。 这是我到目前为止的代码,以及下面的绘图图像,这是一个非常丑陋的适合。
这个问题在这里已经有了答案: The most efficient way to implement an integer based power function pow(int, int) (2
我试图获得指数非常大的 double 值的幂(Java BigInteger 可以包含它(指数),例如:10^30 ) 也就是说,我想找到类似 1.75^(10^30) 或 1.23^(3423453
我有一个数学表达式,例如: ((2-x+3)^2+(x-5+7)^10)^0.5 我需要更换 ^符号到pow C语言的功能。我认为正则表达式是我需要的,但我不知道像专业人士那样的正则表达式。所以我最终
这是我的 previous question on bit flags 的后续内容,我澄清了一些重大误解。 我需要创建这些函数来查找包含零个或多个标志的 int 中的单个位标志: BitBinaryU
我已经在 java 中为 BigInteger 尝试过 modPow() 函数。 但它需要太长时间。 我知道模乘法,甚至也知道求幂。 但由于条件限制,我无法解决这个问题。 a、b 的值可以包含 100
我是一名优秀的程序员,十分优秀!