连续1~20的阶乘的和哪儿出错


#include
double jc(int a,int b);
int main()
{double sum;
for(int i=1;i<=20;i++){
sum=sum+jc(1,i);
}
printf("%.0lf\n",sum);
return 0;
}


double jc(int a,int b){double k=1;
    for(int i=a;i<=b;i++){
        k=k*i;
    }
return k;
}

连续1~20的阶乘的和,末尾换行。

答案是:2,561,327,494,111,820,313‬。计算器得出的也是这个。

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

long long int jc(int a, int b)
{
    long long int k = 1;
    for (int i = a; i <= b; i++)
    {
        k = k * i;
    }
    return k;
}

double类型的数据是保存不了那么大的数的,所以会出错,可以用long long int来保存。如何数更大就要考虑用字符串保存。

sum变量没有初始化啊
改为
double sum = 0.0;

20!=2,432,902,008,176,640,000
无论是double还是long long int都放不下

仅供参考:

#include <stdio.h>
#include <stdlib.h>
int N;
int n,t=2,a=1,b=0;
int *s;
int main(int argc,char **argv) {//雨中飞燕之作
    if (argc==1) {printf("Usage: %s number\nCalculate factorial of number(>=2)\n",argv[0]);return 1;}
    N=atoi(argv[1]);
    if (N<=1) N=10;
    printf("%d!=\n",N);
    n=N;
    s=(int *)calloc(n,sizeof(int));
    if (!s) return 2;
    s[0]=1;s[1]=1;
    for(;a<=*s||(++t<=n?(b=0,a=1):0);(*s==a++&&b)?(*s)++:0)
        s[a]=(b+=s[a]*t)%10000,b/=10000;
    for(printf("%d",s[*s]);--*s>0;) printf("%04d",s[*s]);
    printf("\n");
    free(s);
    return 0;
}


double型输出不对,修改如下,供参考:

#include<stdio.h>
unsigned __int64 jc(int a, int b);
int main()
{
    unsigned __int64 sum = 0;
    for (int i = 1; i <= 20; i++) {
        sum = sum + jc(1, i);
    }
    printf("%I64u\n", sum);
    return 0;
}
unsigned __int64 jc(int a, int b)
{
    unsigned __int64 k = 1;
    for (int i = a; i <= b; i++) {
        k = k * i;
    }
    return k;
}

//2561327494111820313
//  __int64 范围:[-2 ^ 63, 2 ^ 63],即 - 9223372036854775808~9223372036854775807
//  unsigned __int64 范围:[0, 2 ^ 64],0~18446744073709551615 (约1800亿亿)

对的呀!

#include<stdio.h>
double jc(int a,int b);
int main()
{
    double sum;
    for(int i=1;i<=20;i++){
        sum=jc(1,i);
    }
    printf("%.0lf\n",sum);
    return 0;
}
double jc(int a,int b){
    double k=1;
    for(int i=a;i<=b;i++){
        k=k*i;
    }
return k;
}