幂函数输出错误- C
wrong output by power function - 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 %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
是由编译器优化的(这是在编译时计算的)。
相关文章:
- 显示错误输出的简单数组排序程序
- Dijkstra 中的错误输出
- 自定义runtime_error,如果我在 #what 中使用#c_str(),则错误输出始终为空
- 流字符串错误输出
- C++ 异常处理错误输出
- C ++中的错误输出,i = 65530,当我们打印i的值时,它给出-6状态65530
- SSE和iostream:浮点类型的错误输出
- C++将 popen 错误输出读取为字符串
- 部分透视/高斯消除 - 交换列而不是产生错误输出的行
- C++,向量:获得包含 0 的错误输出
- 数组函数错误输出
- CC1plus 错误:输出文件名指定两次
- 字符串错误输出
- 子斯特的错误输出
- 对大量c++错误输出完全一无所知.我认为这与预定义的函数和迭代器有关
- 简单程序的错误输出
- XCode调试器lldb中断,没有错误输出,但程序运行良好
- std::string::append(std::string)错误输出
- 查看大错误输出的顶行
- 使用结构的错误输出