电源功能错误输出 - C.

时间:2013-06-15 10:12:54

标签: c++ c

pow()函数给出了非常奇怪的输出。

我尝试了各种组合:

#include<stdio.h>
#include<math.h>
int main()
{
  int d=1;
  long long n1,n2;
  while(d<10)
  {

     n1=pow(10,d);
     n2=pow(10,d);
     d++;
     printf("%lld %lld\n",n1,n2);
  }
 }

这给出了错误的输出,即99而不是100,就像那样。

现在,如果我删除其中一个变量,ans。是正确的。 如果不是d,我使用常量,ans是正确的。 如果我将n1和n2视为double,则ans是正确的。

因此有两个pow()函数,其中包含变量作为幂和类型转换为整数,这会产生错误的输出。 为什么这种奇怪的行为?

2 个答案:

答案 0 :(得分:3)

这是从浮点值(截断小数,而不是舍入小数)得到整数的情况,以及pow(x, y)转换为exp(log(x) * y)的事实,这将产生结果这与x y 完全不同 - 只是近似为浮点值,例如99.9999996(或100.00002)对于10 2

如果要对其进行舍入,请使用round(pow(x, y))

答案 1 :(得分:2)

对变量使用pow时,其结果为double。分配给int截断它,你得到99而不是99.9999999。

编译器优化使用不带变量的pow(这是在编译时计算的)。