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()函数,其中包含变量作为幂和类型转换为整数,这会产生错误的输出。 为什么这种奇怪的行为?
答案 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
(这是在编译时计算的)。