关于printf函数格式化输出的问题
#include <stdio.h>#include <math.h>
int main()
{
long long sum,temp,weight,i;
sum = 0;
for (i = 0; i < 64; i++)
{
temp = pow(2, i);
sum = sum + temp;
}
weight = sum / 25000;
printf("舍罕王应该给予达依尔 %11d 粒麦子\n", sum);
printf("如果每25000粒麦子为一公斤,那么应该给予 %11d 公斤麦子\n", weight);
return 0;
} 输出结果会报错,并且打印负数,很迷 c语言中,long类型是4个字节,32位,最大的数是2147483647,所以pow(2,31)开始的数据都是溢出了。可以尝试更改一下数据类型,如double。
下面是Python的代码计算结果。
>>> print(2**30)
1073741824
>>> print(2**31)
2147483648
dadaowuming 发表于 2020-10-5 14:16
c语言中,long类型是4个字节,32位,最大的数是2147483647,所以pow(2,31)开始的数据都是溢出了。可以尝试 ...
非常感谢 上机改了一下数据类型,可以实现了。
#include <stdio.h>
#include <math.h>
int main()
{
double sum, temp, weight;
sum = 0;
for (int i = 0; i < 64; i++)
{
temp = pow(2, i);
sum = sum + temp;
printf("%ld %lf%lf\n", i, temp, sum);
}
weight = sum / 25000;
printf("舍罕王应该给予达依尔 %f 粒麦子\n", sum);
printf("如果每25000粒麦子为一公斤,那么应该给予 %f 公斤麦子\n", weight);
return 0;
}
舍罕王应该给予达依尔 18446744073709551616.000000 粒麦子
如果每25000粒麦子为一公斤,那么应该给予 737869762948382.125000 公斤麦子
页:
[1]