CHINA_AK47 发表于 2017-2-28 21:41:51

关于C带你飞第六课国王算米那一题的算法

本帖最后由 CHINA_AK47 于 2017-3-4 17:09 编辑

大家好,我想问一下国王算米那一题中用:
for(int i = 0; i < 64; ++i)
{
temp = pow(2, i);
sum = sum + temp;
}
和用:
for(int i = 0; i < 64; ++i)
{
sum += pow(2, i);
}
两者计算出来的结果为什么不一样!

人造人 发表于 2017-2-28 22:03:49

我这边一样呀,都是18446744073709551616.0000

#include <stdio.h>
#include <math.h>


int main()
{
        doubletemp, sum = 0;
       
#if(0)
        for(int i = 0; i < 64; ++i)
        {
                temp = pow(2, i);
                sum = sum + temp;
        }
#else
        for(int i = 0; i < 64; ++i)
        {
                sum += pow(2, i);
        }
#endif

        printf("%.4lf\n", sum);

        return 0;
}

CHINA_AK47 发表于 2017-3-1 06:09:33

人造人 发表于 2017-2-28 22:03
我这边一样呀,都是18446744073709551616.0000

我用的是WIN10 VISUAL STUDIO 2015 编译出来就是不一样!!!怪了!另问#if、#else,这些#是什么作用?

0mrli0 发表于 2017-3-1 08:44:11

一样{:10_269:}

人造人 发表于 2017-3-1 12:37:23

CHINA_AK47 发表于 2017-3-1 06:09
我用的是WIN10 VISUAL STUDIO 2015 编译出来就是不一样!!!怪了!另问#if、#else,这些#是什么作用?

把你的反汇编代码贴出来

#if
#else
这个是给预处理器看的(传说中的条件编译^_^)

CHINA_AK47 发表于 2017-3-3 20:50:08

本帖最后由 CHINA_AK47 于 2017-3-4 16:38 编辑

感谢个位朋友的答复!!!

我又在LINUX下试了一下,还是不行!!!发现问题可能出在变量的定义上:
用标答“unsigned long long sum = 0;”定义好像确实不行!
用“人造人”朋友的“double sum = 0 ;”定义可以!
页: [1]
查看完整版本: 关于C带你飞第六课国王算米那一题的算法