C#Math.pow()返回Infinity?

时间:2013-12-06 20:09:13

标签: c# casting return double floating-point-precision

我在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计算器 请我需要变量类型是返回相同的窗口计算器

4 个答案:

答案 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