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,而第二个的累加有准确的数字结果呢?
for(int i=0;i<64;i++){
sum=sum+(unsigned long long)pow(2,i);
} 我想问一下,两个代码中的变量 sum 在循环前都有初始化为 0 值? 本帖最后由 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); jackz007 发表于 2022-6-9 12:53
我想问一下,两个代码中的变量 sum 在循环前都有初始化为 0 值?
有的,有初始化为0值,还是不行的 jhq999 发表于 2022-6-9 13:01
棋盘麦粒问题可以很多种解2^0=1b 2^1=10b 2^2 =100b……2^63=1(后面63个0)b;
所以加在一起就是64个1
? jhq999 发表于 2022-6-9 11:53
大佬我按照你这样的试了跟作业给出的答案不对呀 代码要给全,sum和temp是什么变量 本帖最后由 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:38 编辑
编程追风梦 发表于 2022-6-9 13:26
?
加一起二进制64个1;0xFFFFFFFFFFFFFFFF
sum(i-1)=2^i-1;
sum(i)=2^i+2^i-1 #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]