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類型
//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)文章
華為云開(kāi)發(fā)工具CodeArts IDE for C/C++開(kāi)發(fā)使用指南
CodeArts IDE是一個(gè)集成開(kāi)發(fā)環(huán)境(IDE),它提供了開(kāi)發(fā)語(yǔ)言和調(diào)試服務(wù),本文主要介紹了華為云開(kāi)發(fā)工具CodeArts IDE for C/C++ 開(kāi)發(fā)使用指南,感興趣的可以了解一下2023-08-08
C++ const的使用及this指針常方法(面試最愛(ài)問(wèn)的this指針)
這篇文章主要介紹了C++ const的使用,this指針,常方法(面試最愛(ài)問(wèn)的this指針),本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-04-04
c語(yǔ)言實(shí)現(xiàn)通訊錄管理系統(tǒng)詳細(xì)實(shí)例
這篇文章主要給大家介紹了關(guān)于c語(yǔ)言實(shí)現(xiàn)通訊錄管理系統(tǒng)的相關(guān)資料,通訊錄管理系統(tǒng)是一種常見(jiàn)的應(yīng)用程序,可以用來(lái)管理聯(lián)系人的信息,包括姓名、電話號(hào)碼、地址等,需要的朋友可以參考下2023-07-07
C語(yǔ)言約瑟夫環(huán)的實(shí)現(xiàn)
這篇文章主要介紹了C語(yǔ)言約瑟夫環(huán)的實(shí)現(xiàn)的相關(guān)資料,這里主要是利用數(shù)據(jù)數(shù)據(jù)結(jié)果中循環(huán)鏈表來(lái)實(shí)現(xiàn),需要的朋友可以參考下2017-08-08
淺析C/C++中的可變參數(shù)與默認(rèn)參數(shù)
C支持可變參數(shù)的函數(shù),這里的意思是C支持函數(shù)帶有可變數(shù)量的參數(shù),最常見(jiàn)的例子就是我們十分熟悉的printf()系列函數(shù)。我們還知道在函數(shù)調(diào)用時(shí)參數(shù)是自右向左壓棧的2013-09-09
C/C++中for語(yǔ)句循環(huán)用法以及練習(xí)舉例
for語(yǔ)句是一種循環(huán)語(yǔ)句,它是對(duì)while語(yǔ)句的推廣,下面這篇文章主要給大家介紹了關(guān)于C/C++中for語(yǔ)句循環(huán)用法以及練習(xí)舉例的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-03-03
C++數(shù)據(jù)結(jié)構(gòu)之list詳解
list是一種序列式容器。list容器完成的功能實(shí)際上和數(shù)據(jù)結(jié)構(gòu)中的雙向鏈表是極其相似的,list中的數(shù)據(jù)元素是通過(guò)鏈表指針串連成邏輯意義上的線性表,也就是list也具有鏈表的主要優(yōu)點(diǎn),即:在鏈表的任一位置進(jìn)行元素的插入、刪除操作都是快速的2021-11-11

