幂函数输出错误- C

wrong output by power function - C

本文关键字:错误 输出 函数      更新时间:2023-10-16

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 %lldn",n1,n2);
  }
 }

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

现在如果我删除一个变量,ans.是正确的。如果我用常数代替d, ans是正确的。如果我取n1和n2为双精度,ans是正确的。

所以有两个pow()函数,都有变量作为幂,类型转换为整数,会产生不好的输出。为什么会有这种奇怪的行为?

这是一个从浮点值(截断小数,而不是四舍五入)生成整数的情况,以及pow(x, y)转换为exp(log(x) * y)的事实,这将产生与xy不完全相同的结果-只是近似于浮点值,例如102的99.9999996(或100.00002)。

如果你想四舍五入,使用round(pow(x, y))

当您使用pow与变量时,其结果是double。给int赋值会截断它,你得到的是99而不是99.9999999。

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