pow函数问题

    不要随便用pow函数

    ——这是我这几天写程序的切身体会,如果需要用整数的乘方运算,自己写一个函数吧。
    昨天在网上做一道题,其中我写了一句n = (int) pow ( 5.0 , ( double ) k );我认为应该没有问题。因为math库里的pow函数的两个参数和返回值都是浮点型。返回的数我只要它的整数部分(本来也应该是个整数)。
    于是后来题目一直不能过,而且我的两个编译器( VC6和CFREE )算出的结果还不一样。通过一晚上的调试,我才找到这里。后来自己写了一个pow函数,解决了问题。
    我们可以来做个试验,写一个程序:

#include <stdio.h>
#include <math.h>
int main()
{
	for(int i = 0 ; i < 10 ; i++)
	{
		long n;
		n = (int)pow(5,i);
		printf("%dn",n);
	}
	return 0;
}

    你放在VC6下运行,毫无问题是吗,输出为:

1
5
25
125
625
3125
15625
78125
390625
1953125

    你放在linux下编译运行(或者在win下用cfree这种用mingw32编译器的软件编译运行),结果如下:

1
5
24
124
624
3125
15624
78124
390624
1953124

    看到了么?从52开始就错。你把n = ( int ) pow ( 5 , i ); 换成n = (int) pow ( 5.0 , ( double ) k ); 结果一样。为什么,我也不知道为什么。你算3的乘方都没出问题。下次我真的不敢用pow函数了。

    题目交了一晚上过不了,因为评测系统用的是linux,而我是在VC6下调试运行的。

    无力吐槽C的兼容性。后来还遇到了一个64位整数的问题,一样也是因为不同平台下不同编译器出的结果就不一样,这些兼容性问题在一道题里面集中反映了出来,也真是不简单。(关于这个64位整数的问题我以后会讲讲)

    

相关推荐: WebSth 指纹识别插件简要分析

    今天才在某个论坛上看到这个网站:http://websth.com/, 深感所知甚晚啊,自己一直想做的web指纹识别,已经有童鞋做成chrome插件发布了,并且功能还算比较强大,不过准确性确实有待提高。于是我下载了其源码并开始围观一…

© 版权声明
THE END
喜欢就支持一下吧
点赞0
分享
评论 抢沙发

请登录后发表评论