Weylen


私信TA

用户名:Weylen

访问量:2071

签 名:

等  级
排  名 33232
经  验 460
参赛次数 0
文章发表 2
年  龄 0
在职情况 学生
学  校 SZU
专  业

  自我简介:

TA的其他文章

解题思路:



注意事项:

编这个算法很轻松,但是要注意几点

①要用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 人评分

  评论区

  • «
  • »