【C語言】求階乘序列前N項(xiàng)和

本題要求編寫程序,計(jì)算序列 1!+2!+3!+? 的前N項(xiàng)之和。

輸入格式:

輸入在一行中給出一個不超過12的正整數(shù)N。

輸出格式:

在一行中輸出整數(shù)結(jié)果。

輸入樣例:

5

輸出樣例:

153

代碼1:

#include <stdio.h>
int fact(int n)
{
    int factorial = 1;
    for (; n >= 1; n--)
    {
        factorial *= n;
    }
    return factorial;
}
int main()
{
    int n, sum = 0;
    scanf("%d", &n);
    for (int x = 1; x <= n; x++)
    {
        sum += fact(x);
    }
    printf("%d", sum);
    return 0;
}

代碼2:

#include <stdio.h>
int main()
{
    int x = 1, n, sum = 0;
    scanf("%d", &n);
    for (int i = 1; i <= n; i++)
    {
        x *= i;
        sum += x;
    }
    printf("%d", sum);
    return 0;
}

提交截圖:

image.png

解題思路:

代碼1先定義了一個計(jì)算階乘的函數(shù),繼而在主函數(shù)中調(diào)用并累加求和,可讀性較強(qiáng)。

代碼2邏輯性很強(qiáng),算法很好,所以建議讀者記住。因?yàn)檫壿嬓詮?qiáng),所以只看可能不易理解,自己計(jì)算一下,在紙上將過程寫出來就明白了。

假如 n = 4:

  1. 當(dāng) i = 1 時,m = 1,sum = 1。
  2. 當(dāng) i = 2 時,m = 1 \times 2,sum = 1 + 1 \times 2。
  3. 當(dāng) i = 3 時,m = 1 \times 2 \times 3,sum = 1 + 1 \times 2 + 1 \times 2 \times 3。
  4. 當(dāng) i = 4 時,m = 1 \times 2 \times 3 \times 4,sum = 1 + 1 \times 2 + 1 \times 2 \times 3 + 1 \times 2 \times 3 \times 4。

看出規(guī)律來了嗎? m 的值是一直往下乘,乘以 i 之前 m 的值是( i – 1)的階乘,乘以 i 之后 m 的值就是 i 的階乘了。這樣 i 循環(huán)到多少, m \times i 就立刻將這個數(shù)的階乘計(jì)算出來,然后加到 sum 中。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容