解決問題:C語言利用 for循環(huán):求 1! + 2! + 3! + ... + n!
代碼實現(xiàn)
# include <stdio.h>
int main(void)
{
int n = 0;
int i = 0;
int m = 1;
int sum=0;
printf("請輸入n的值:");
scanf("%d", &n);
for (i=1; i<=n; ++i)
{
m = m * i;
sum = sum +m;
}
printf ("sum = %d\n", sum);
return 0;
}
知識點剖析
這個程序雖然短,但邏輯性很強,算法很好,所以建議讀者記住。因為邏輯性強,所以只看是很難明白的,自己在紙上試一下,將自己當成計算機一步步地計算就明白了。
假如 n=4:文章來源:http://www.zghlxwxcb.cn/news/detail-502790.html
- 當 i=1 時,m=1,sum=1。
- 當 i=2 時,m=1×2,sum=1+1×2。
- 當 i=3 時,m=1×2×3,sum=1+1×2+1×2×3。
- 當 i=4 時,m=1×2×3×4,sum=1+1×2+1×2×3+1×2×3×4。
看出規(guī)律來了嗎?m 的值是一直往下乘,乘以 i 之前 m 的值是(i–1)的階乘,乘以 i 之后 m 的值就是 i 的階乘了。這樣 i 循環(huán)到多少,m*i 就立刻將這個數(shù)的階乘計算出來,然后加到 sum 中。文章來源地址http://www.zghlxwxcb.cn/news/detail-502790.html
到了這里,關(guān)于C語言:求 1! + 2! + 3! + ... + n!(for循環(huán))的文章就介紹完了。如果您還想了解更多內(nèi)容,請在右上角搜索TOY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!