解题思路:
注意事项:
编这个算法很轻松,但是要注意几点
①要用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语言训练-字符串正反连接 (C语言代码)浏览:622 |
1157题解浏览:716 |
回文数字 (C语言代码)浏览:2510 |
C语言程序设计教程(第三版)课后习题9.3 (C语言代码)浏览:679 |
蛇行矩阵 (C语言代码)浏览:507 |
淘淘的名单 (C语言代码)浏览:1228 |
C语言程序设计教程(第三版)课后习题7.4 (C语言代码)浏览:492 |
盐水的故事 (C语言代码)浏览:1529 |
C语言程序设计教程(第三版)课后习题5.7 (C语言代码)浏览:567 |
小O的数字 (C语言代码)浏览:1411 |