大胆智多星 发表于 2022-6-9 11:44:44

c语言问题求解

本帖最后由 大胆智多星 于 2022-6-9 11:47 编辑

for(i=0;i<64;i++){
               
                sum=sum+pow(2,i);
               
        }跟
for(i=0;i<64;i++){
               
                temp=pow(2,i);
                sum+=temp;
               
        }


为啥第一个的累加结果为0,而第二个的累加有准确的数字结果呢?

jhq999 发表于 2022-6-9 11:53:20

for(int i=0;i<64;i++){

                sum=sum+(unsigned long long)pow(2,i);

      }

jackz007 发表于 2022-6-9 12:53:23

      我想问一下,两个代码中的变量 sum 在循环前都有初始化为 0 值?

jhq999 发表于 2022-6-9 13:01:32

本帖最后由 jhq999 于 2022-6-9 13:16 编辑

棋盘麦粒问题可以很多种解2^0=1b 2^1=10b 2^2 =100b……2^63=1(后面63个0)b;
所以加在一起就是64个1
unsigned long long sum=1;
sum=sum<<63;
sum=sum-1+sum;
printf("%llu   %llx",sum,sum);

大胆智多星 发表于 2022-6-9 13:26:56

jackz007 发表于 2022-6-9 12:53
我想问一下,两个代码中的变量 sum 在循环前都有初始化为 0 值?

有的,有初始化为0值,还是不行的

编程追风梦 发表于 2022-6-9 13:26:56

jhq999 发表于 2022-6-9 13:01
棋盘麦粒问题可以很多种解2^0=1b 2^1=10b 2^2 =100b……2^63=1(后面63个0)b;
所以加在一起就是64个1

大胆智多星 发表于 2022-6-9 13:32:11

jhq999 发表于 2022-6-9 11:53


大佬我按照你这样的试了跟作业给出的答案不对呀

风车呼呼呼 发表于 2022-6-9 13:42:04

代码要给全,sum和temp是什么变量

jhq999 发表于 2022-6-9 14:28:12

本帖最后由 jhq999 于 2022-6-9 14:30 编辑

大胆智多星 发表于 2022-6-9 13:32
大佬我按照你这样的试了跟作业给出的答案不对呀

#include <stdio.h>
#include <math.h>
int main()
{
    unsigned long long sum=0,i;
    for(i=0;i<64;i+=1)
    {
      sum+=(unsigned long long)pow(2,i);
    }
    printf("%llu ",sum);
    return 0;
}

#include <stdio.h>
int main()
{
    unsigned long long sum=0,i;
    for(i=1;i;i<<=1)
    {
      sum+=i;
    }
    printf("%llu ",sum);
    return 0;
}

18446744073709551615
Process returned 0 (0x0)   execution time : 0.239 s
Press any key to continue.

jhq999 发表于 2022-6-9 14:32:25

本帖最后由 jhq999 于 2022-6-9 14:38 编辑

编程追风梦 发表于 2022-6-9 13:26


加一起二进制64个1;0xFFFFFFFFFFFFFFFF
sum(i-1)=2^i-1;
sum(i)=2^i+2^i-1

jackz007 发表于 2022-6-9 15:04:31

#include <stdio.h>

int main(void)
{
      unsigned long long i , sum                     ;
      for(sum = i = 0 ; i < 64 ; i ++) sum += 1LL << i ;
      printf("%llu\n" , sum)                           ;
      printf("0x%llx\n" , sum)                         ;
}
      编译、运行实况:
D:\\>g++ -o x x.c

D:\\>x
18446744073709551615
0xffffffffffffffff

D:\\>
页: [1]
查看完整版本: c语言问题求解