#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;
}