wsym6885986 发表于 2022-5-12 21:02:35

带你学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:31:21

本帖最后由 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;
}

wsym6885986 发表于 2022-5-12 21:41:51

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;
}

eagle.jy 发表于 2023-6-19 19:55:26

wsym6885986 发表于 2022-5-12 21:41
非常感谢,请问为什么要把pow强转成 unsigned long long 呢?
刚才查帖子说是因为pow是double型,但是即 ...

请问解决了吗,我现在也在找这个问题答案
页: [1]
查看完整版本: 带你学C带你飞--S1E6作业问题