1 #include
2 int main()
3 {
4 int i=0;
5 long temp=1;
6 long sum=0;
7 for(i=1;i<=20;i++)
8 {
9 temp*=i;
10 sum+=temp;
11 }
12 printf("sum=%ld\n",sum);
13 return 0;
14 }
___________________
cl之后,执行:
____________________
Microsoft (R) 32-bit C/C++ Optimizing Compiler Version 12.00.8168 for 80x86
Copyright (C) Microsoft Corp 1984-1998. All rights reserved.
baidu.c
Microsoft (R) Incremental Linker Version 6.00.8168
Copyright (C) Microsoft Corp 1992-1998. All rights reserved.
/out:baidu.exe
baidu.obj
sum=268040729
请按 ENTER 或其它命令继续
_________________
to 楼上:
你的for里边的sum1每次重新从1开始算,很浪费的,直接用上一次的结果就行.
#include
int main()
{
int i=0;
long temp=1;
long sum=0;
for(i=1;i<=20;i++)
{
temp*=i;
sum+=temp;
}
printf("sum=%ld\n",sum);
return 0;
}
利用for循环期求出第n项阶乘的积,然后前n-1项的阶乘的和加上第n项阶乘就是所求。
输入任意数n,可算得0!+1!+……+n!
#include "stdio.h"
main()
{
int i,j,sum1,sum=0,n;
printf("请输入n:\n");
scanf("%d",&n);
for(i=1;i<=n;i++)
{
sum1=1;
for(j=1;j<=i;j++)
{
sum1=sum1*j;
}
sum=sum+sum1;
}
if(n==0) sum=1;
printf("\n阶乘的和为:%d",sum);
}
内层for语句是求i的阶乘,外层for语句是求0!+1!+……+n!
#include
main()
{
int i,num=1,sum=0;//定义并且初始化
for(i=1;i<=20;i++)
{
num*=i;//将每个数的阶乘放在num中
sum+=num;//求各个数阶乘的和放在sum中
}
printf("the sum of 1!+...+20!=%d.\n",sum);//输出结果
}
#include
/* 递归求阶乘,注意处理范围 */
double jiecheng(double nI) {
double nS = 0;
if (nI>1) nS += jiecheng(nI-1);
double nM = nI;
while (nI!=1) {
nM *= (nI-1);
nI--;
}
return (nS+nM);
}
int main() {
printf("result: %lf\n\n",jiecheng(20)); //误差为20左右
return 0;
}