pow的误差

pow()是头文件cmath/math.h里面的一个求x^y的函数。

在刚开始的时候用它特别好用!但是今天再看一篇博客的时候(为了引入某个知识点),发现pow居然会有误差1.

pow的误差_第1张图片

如上图,明明结果应该是125,答案却是124。

经过调查发现,pow原型为:double pow(double ,double),也就是说,pow返回类型是double类型,赋值给int会引起小数部分的强行截断。(为什么会有小数???可能是算法本身的问题??)

就引入了快速幂求x^y。

而将返回类型修改为double之后:

pow的误差_第2张图片

问题解决的促不及防。

以后用pow一定要记得传给double!!太恐怖了。 

你可能感兴趣的:(c++学习心得)