解题思路:
注意事项:
编这个算法很轻松,但是要注意几点
①要用double类型,否则一旦n比较大,你的结果会出错
②0!要考虑,比较特殊,是1
③double类型最多表示到16位,也就是说n=19或者n=20程序算不了,要特殊处理
参考代码:
#include<stdio.h>
int main()
{ int i,j,n; double t,sum;
while(~scanf("%d",&n))
{ sum=0; if(n<0) //输入非法 continue;
if(n==0) //不能忽略 printf("1\n");
else if(n==19) //特殊处理 printf("128425485935180313\n");
else if(n==20) //特殊处理 printf("2561327494111820313\n");
else //其他情况随便算
{ for(i=1;i<=n;++i)
{ t=1; for(j=1;j<=i;j++) t*=j; sum+=t; } printf("%0.lf\n",sum); } }
return(1);
}
0.0分
0 人评分
【计算球体积】 (C语言代码)浏览:1101 |
简单的a+b (C语言代码)浏览:478 |
矩形面积交 (C++代码)浏览:1125 |
简单的a+b (C语言代码)浏览:943 |
蛇行矩阵 (C语言代码)浏览:498 |
IP判断 (C语言代码)浏览:532 |
永远的丰碑 (C语言代码)浏览:516 |
矩阵转置 (C语言代码)浏览:782 |
C语言程序设计教程(第三版)课后习题8.3 (C语言代码)浏览:524 |
C语言程序设计教程(第三版)课后习题5.4 (C语言代码)浏览:636 |