带你学C带你飞--S1E6作业问题
本帖最后由 wsym6885986 于 2022-5-12 21:08 编辑#include <stdio.h>
#include <math.h>
int main(){
unsigned long long sum = 0;
int i;
for(i = 0;i<64; i++ ){
sum += pow(2,i);
}
printf("一共应给予%llu粒麦子\n",sum);
printf("共%llu公斤麦子\n",sum/25000);
return 0;
}
使用DEV C++
运行结果 sum = 0;
如果加入中间变量 temp = pow(2,i) 再令 sum = sum + temp;
结果就是 long long 的最大值
想问一下这是什么原因?
sum += pow(2,i);
和
temp = pow(2,i);
sum += temp;
这两种写法为什么结果差1呢? 本帖最后由 gandixiwang 于 2022-5-12 21:36 编辑
#include <stdio.h>
#include <math.h>
int main(){
unsigned long long sum = 0;
int i;
for(i = 0;i<64; i++ ){
sum += (unsigned long long)pow(2,i);
}
printf("一共应给予%llu粒麦子\n",sum);
printf("共%llu公斤麦子\n",sum/25000);
return 0;
} gandixiwang 发表于 2022-5-12 21:31
非常感谢,请问为什么要把pow强转成 unsigned long long 呢?
刚才查帖子说是因为pow是double型,但是即便是double,也不会出现小数啊
通过测试发现当i=53时,会出现sum多1的情况
请问为什么会这样呀?
#include <stdio.h>
#include <math.h>
int main(){
unsigned long long sum = 0;
unsigned long long n = 0;
unsigned long long temp = 0;
int i;
int k = 0;
for(i = 0;i<64; i++ ){
sum += pow(2,i);
temp = pow(2,i);
n = n + temp;
if(i == 52){
printf("i = %d\n",i);
printf("n = %llu\n",n);
printf("sum = %llu\n",sum);
printf("temp = %llu\n",temp);
}
if(sum != n && k == 0){
k = 1;
printf("i = %d\n",i);
printf("n = %llu\n",n);
printf("sum = %llu\n",sum);
printf("temp = %llu\n",temp);
}
}
printf("一共应给予%llu粒麦子\n",sum);
printf("共%llu公斤麦子\n",sum/25000);
return 0;
} wsym6885986 发表于 2022-5-12 21:41
非常感谢,请问为什么要把pow强转成 unsigned long long 呢?
刚才查帖子说是因为pow是double型,但是即 ...
请问解决了吗,我现在也在找这个问题答案
页:
[1]