我在c#return infinity中遇到Math.pow问题,例如:
double a=65;
double b=331;
Console.Write(Math.Pow(a,b));
//but return infinty
但我的电脑的计算器不返回65 ^ 331无穷大有实数返回 这个:1.1866456424809823888425970808655e + 600
我使用强制转换为(长)但结果不同于Windows计算器 请我需要变量类型是返回相同的窗口计算器
答案 0 :(得分:6)
double
有一个limited range;它无法存储此号码。
使用BigInteger
。
答案 1 :(得分:5)
Math.pow
可以使用的范围有限。有关详细信息,请参阅MSDN docs。
我不确定你为什么要计算65^331
。一种解决方法是使用BigInteger class:
BigInteger result = new BigInteger(Math.pow(65, 331))
如果这不起作用,那么总会有很好的增长:
BigInteger product = 1;
BigInteger a = 65;
for (int i = 0; i < 331; i++) {
product = BigInteger.Multiply(product, a);
}
这应该返回你想要的值。
答案 2 :(得分:1)
如果该值超出该类型的范围,则返回无穷大。所以,是的,它可以返回无穷大。
答案 3 :(得分:0)
您应该阅读有关IEEE754浮点的信息,了解其原因。基本上,一些放大器不适合机器浮点格式(通常为32或64位)。
C++ 32bit vs 64bit floating limit有关于这些机器词会保留的最大值的信息,但简而言之BigInteger
是处理如此大数字的正确方法。
例如在Python中(整数可以是任意大小):
>>>65**331
1186645642480982388842597080865547928975
8025124874226281286044593977851408626647
1648153565617569287290861365843808026786
6910699252797849188956233075264639216543
7504315383537154855617697699290248015932
2796464262757682229990775670822339468164
8291964549985945784276239845489091652362
0705054470856040542942680710474683036796
8985285030088564076789292802170819942388
3788422698744095551323695360171668455050
6467003204582429046323962276940067249678
5724338639806479202984280300919968748839
9063613316621160349502633982277117451890
1573217436770532915029575301234171172274
1482981646754524263087660074234008789062
5L