输出错误
本帖最后由 流泪的小鳄鱼 于 2018-9-18 16:09 编辑#include<stdio.h>
#include<math.h>
int main()
{
unsigned long long sum=0;
// unsigned long long temp;
unsigned long long a;
int i;
for(i=0;i<=64;i++)
{
//temp=pow(2,i);
//sum=sum+temp;
sum=sum+pow(2,i);
}
a=sum/25000;
printf("舍罕王应该给予达依尔%llu粒麦子!\a\n",sum); //数据存储超出空间
printf("如果每25000粒麦子为1Kg,那么应该给%llu公斤麦子!\a\n",a);
system("pause");
return 0;
}
程序没有错误,但是就是最后结果为0;进行调试后发现当i=63时,sum突然变为0;我怀疑可能是因为没有设置中间变量temp,但是我觉得没有理论支撑我这个观点,求大神解 pow() 只有 double,需要强制转型 (unsigned long long)pow()
循环 64,好像溢出了,2^63-1 claws0n 发表于 2018-9-18 12:01
pow() 只有 double,需要强制转型 (unsigned long long)pow()
循环 64,好像溢出了,2^63-1
这个能不能直接进行强制转换,像sum=sum+(unsigned long long(pow(2,i)));这样类似的,我这样定义直接出错,难道说不能直接强制转换,只能通过中间变量吗? 本帖最后由 流泪的小鳄鱼 于 2018-9-18 16:05 编辑
claws0n 发表于 2018-9-18 12:01
pow() 只有 double,需要强制转型 (unsigned long long)pow()
循环 64,好像溢出了,2^63-1
流泪的小鳄鱼 发表于 2018-9-18 15:37
这个能不能直接进行强制转换,像sum=sum+(unsigned long long(pow(2,i)));这样类似的,我这样定义直接出 ...
这样转换错了,括号在前面而已。你的问题不是这个,循环不能到 64。最大到 2^63-1,所以循环只能 < 63 claws0n 发表于 2018-9-18 16:13
这样转换错了,括号在前面而已。你的问题不是这个,循环不能到 64。最大到 2^63-1,所以循环只能 < 63
嗯嗯,我意识到了,非常感谢{:5_110:}
页:
[1]