远榐


私信TA

用户名:dotcpp0712660

访问量:473

签 名:

等  级
排  名 26306
经  验 576
参赛次数 0
文章发表 10
年  龄 0
在职情况 学生
学  校 贵州大学
专  业

  自我简介:

解题思路:这里主要先分析阶乘求和,主要有两个步骤:第一个步骤是从n递减相乘,再将n-1重新循环再递减相乘,直到n=1;

这部分代码如下:

 for (a = n; a >= 1; a--) {                 //这里用n--,将n-1代入循环

    c=1;                                             //如果不把c值每次初始化为1,则下一次b循环会将上一次循环的c值代入运算,导致结果变得很大,结果错误

        for (b = a; b >= 1; b--) {

            c = b * c;                          //递减相乘

           

        }


第二步将所有积相加赋值给变量sn

 sn = sn + c;                              //这部分代码是在第一个for循环里



注意事项:第一次设置了int 型,,会显示答案错误,要设置long long int 型变量就能通过

参考代码:

#include<stdio.h>

int main() {

     long long int a, b, c, n,sn;        //int 型变量会报错,要用long long int 型变量,如果a,b,c,n单独设置成int型会报错

    a = b =sn= 0;


    scanf("%lld", &n);                     //这里可以用%lld也可以用%d

    for (a = n; a >= 1; a--) {

    c=1;                                             //如果不把c值每次初始化为1,则下一次b循环会将上一次循环的c值代入运算,导致结果变得很大,结果错误

        for (b = a; b >= 1; b--) {

            c = b * c;

           

        }

        sn = sn + c;

    }

    printf("%lld", sn);             //这里要跟long long int 型变量匹配,用%lld

    return 0;

}


 

0.0分

0 人评分

  评论区

  • «
  • »