#include <stdio.h> void main() { int m,n,z; doub

#include void main() { int m,n,z; double sum=0; for(m=1;m<=20;m++) { for(n=1,z=1;n<=m;n++) { z*=n; } sum+=z; } printf("%lf\n",sum); } 求问C中1到20的阶乘之和这么求有哪里错了吗? 一直求不对,希望有大佬帮忙解答。

因为int最大表示2^31-1,也就是2147483647(21亿)。但是12!是4亿多,13!是62亿多。20!有19位

你用z(int)来存放每个数的阶乘,到了13!之后就出错了,z就不是正确的阶乘结果。导致你的sum出错。

你可以把所有变量全用long long int,这个在64位机上可以表示8个字节,可以达到19位,刚好可以记录20!,不可以记录21!