C語(yǔ)言求階乘之和的三種實(shí)現(xiàn)方法(先階乘再累加)
題目:

此處題目是以1-20的階乘之和舉例
方法一:使用一層for循環(huán)實(shí)現(xiàn) 代碼簡(jiǎn)單快捷容易理解
代碼示例如下:
#include<stdio.h>
int main()
{
double a = 1, sum = 0;//因?yàn)樽詈笾悼赡軙?huì)超出int所能接收的范圍 故用double
int n, i;
scanf("%d", &n);//注意scanf_s和scanf的使用場(chǎng)景
for (i = 1; i <= n; i++)
{
a = a*i;
sum = sum + a;
}
printf("%lld", sum);//double的輸入格式要對(duì)
return 0;
}運(yùn)行結(jié)果如下:

方法二:使用兩層for循環(huán)嵌套
代碼示例如下:
//需要注意對(duì)于1-20階乘結(jié)果已經(jīng)超出了int能夠接收的范圍
// 故用double類(lèi)型
//1.遍歷獲取每一個(gè)數(shù)字[1-20]
//2.對(duì)每一個(gè)數(shù)進(jìn)行階乘
//3.對(duì)每個(gè)數(shù)字的階乘結(jié)果進(jìn)行求和
int main()
{
double total_sum = 0.0;
for (int i = 1; i <= 20; i++)//i控制求和
{
//i=8 ---> 8*7*6*....*1
double single_num = 1.0;
for (int j = i; j > 0; j--)
{
single_num *= j;//j控制階乘
}
total_sum += single_num;
}
printf("%lf\n", total_sum);
return 0;
}運(yùn)行結(jié)果如下:

方法三:函數(shù)遞歸實(shí)現(xiàn)
#include<stdio.h>
long int fac(unsigned int n) //定義為long int 型,避免溢出
{
long int f;
if (n == 0) return; //當(dāng)n=0是,遞歸法到盡頭,依次返回函數(shù)值。
f = fac(n - 1) * n;
return (f); //返回最后一次函數(shù)值,即單次階乘的最后結(jié)果
}
int main()
{
unsigned int n;
long int s =0;
int i;
scanf_s("%d", &n);//此處注意scanf_s與scanf的使用場(chǎng)景
for (i = 1; i <= n; i++) s += fac(i); //以循環(huán)控制階乘的和。fac函數(shù)每一次的返回值作為s的自加值
printf("%ld", s);
return 0;
}#include<iostream>
#include<cmath>
double fac(double t)
{
if (t == 1)
return 1;
else
return t * fac(t - 1);
}
int main()
{
using namespace std;
double i, n, sum = 0;
cin >> n;
if (n > 14)
return 0;
for (i = 1; i < n; i++)
{
double b = fac(i);
sum += b;
}
cout << "sum =" << sum << endl;
printf("%lf\n", sum);
return 0;
}代碼運(yùn)行結(jié)果如下:

編者注:以上對(duì)本小題的代碼編寫(xiě)的多種方法,歡迎大家收藏借鑒并轉(zhuǎn)發(fā);
總結(jié)
到此這篇關(guān)于C語(yǔ)言求階乘之和的三種實(shí)現(xiàn)方法的文章就介紹到這了,更多相關(guān)C語(yǔ)言求階乘之和內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C語(yǔ)言結(jié)構(gòu)體(struct)常見(jiàn)使用方法(細(xì)節(jié)問(wèn)題)
這篇文章主要介紹了C語(yǔ)言結(jié)構(gòu)體(struct)常見(jiàn)使用方法(細(xì)節(jié)問(wèn)題),需要的朋友可以參考下2017-03-03
C++?move()函數(shù)及priority_queue隊(duì)列使用記錄
move(obj)函數(shù)的功能是把obj當(dāng)做右值處理,可以應(yīng)用在對(duì)象的移動(dòng)上,這篇文章主要介紹了C++?move()函數(shù)及priority_queue隊(duì)列使用記錄,需要的朋友可以參考下2023-01-01
c++ 完備的運(yùn)行時(shí)類(lèi)型信息(動(dòng)態(tài)類(lèi)型信息)
這篇文章主要介紹了c++ 完備的運(yùn)行時(shí)類(lèi)型信息,需要的朋友可以參考下2017-07-07
C語(yǔ)言實(shí)現(xiàn)會(huì)員計(jì)費(fèi)系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言實(shí)現(xiàn)會(huì)員計(jì)費(fèi)系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-05-05
C語(yǔ)言統(tǒng)計(jì)輸入字符各個(gè)字母出現(xiàn)頻率的解題思路
這篇文章主要介紹了C語(yǔ)言統(tǒng)計(jì)輸入字符各個(gè)字母出現(xiàn)頻率的解題思路,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2015-08-08
C++11中列表初始化機(jī)制的概念與實(shí)例詳解
在我們實(shí)際編程中,我們經(jīng)常會(huì)碰到變量初始化的問(wèn)題,對(duì)于不同的變量初始化的手段多種多樣,下面這篇文章主要給大家介紹了關(guān)于C++11中列表初始化機(jī)制的相關(guān)資料,需要的朋友可以參考下2021-11-11
C語(yǔ)言實(shí)現(xiàn)單鏈表的基本功能詳解
鏈表是一個(gè)結(jié)構(gòu)體實(shí)現(xiàn)的一種線(xiàn)性表,它只能從前往后,不可以從后往前,在實(shí)現(xiàn)單鏈表的操作時(shí),需要用指針來(lái)操作。本文主要介紹了實(shí)現(xiàn)單鏈表的基本功能的代碼示例,具有一定價(jià)值,感興趣的同學(xué)可以學(xué)習(xí)一下2021-11-11
基于C++實(shí)現(xiàn)kinect+opencv 獲取深度及彩色數(shù)據(jù)
本文的主要思想是Kinect SDK 讀取彩色、深度、骨骼信息并用OpenCV顯示,非常的實(shí)用,有需要的小伙伴可以參考下2015-12-12

