迪迦


私信TA

用户名:dotcpp0776032

访问量:1127

签 名:

等  级
排  名 6760
经  验 1380
参赛次数 0
文章发表 25
年  龄 0
在职情况 学生
学  校
专  业

  自我简介:

解题思路:
先求出每一项的阶乘,再把每一项的结果相加,其中,阶乘的求法可以是通过递归来求,也可以在循环中一次一次的把每个数相乘求得对应的阶乘。这在循环中可以用双层循环,也可以只用一个循环,双层循环的话,一个循环用来控制求和,一个用来求阶乘,单个循环的话求和和求阶乘写在一起,每求一个阶乘就把它加上。

注意事项:
先求阶乘在求和


参考代码:

双层循环:

#include <stdio.h>
#include <math.h>

int Input()
{
    int N;
    scanf("%d", &N);
    return N;
}

long long int FactorialSum(int N)
{
    long long int sum = 0, fact;
    for (int i = 1; i <= N; i++)
    {
        fact = 1;
        for (int j = 1; j <= i; j++)
        {
            fact *= j;
        }
        sum += fact;
    }
    return sum;
}

void Output(long long int sum)
{
    printf("%lld", sum);
}

int main()
{
    Output(FactorialSum(Input()));
    return 0;
}


单层循环:

#include <stdio.h>
#include <math.h>

int Input()
{
    int N;
    scanf("%d", &N);
    return N;
}

long long int FactorialSum(int N)
{
    long long int sum = 0, fact = 1;
    for (int i = 1; i <= N; i++)
    {
        fact *= i;
        sum += fact;
    }
    return sum;
}

void Output(long long int sum)
{
    printf("%lld", sum);
}

int main()
{
    Output(FactorialSum(Input()));
    return 0;
}


 

0.0分

0 人评分

  评论区

  • «
  • »