C語言求階乘之和的三種實(shí)現(xiàn)方法(先階乘再累加)
題目:
此處題目是以1-20的階乘之和舉例
方法一:使用一層for循環(huán)實(shí)現(xiàn) 代碼簡單快捷容易理解
代碼示例如下:
#include<stdio.h> int main() { double a = 1, sum = 0;//因?yàn)樽詈笾悼赡軙鰅nt所能接收的范圍 故用double int n, i; scanf("%d", &n);//注意scanf_s和scanf的使用場景 for (i = 1; i <= n; i++) { a = a*i; sum = sum + a; } printf("%lld", sum);//double的輸入格式要對 return 0; }
運(yùn)行結(jié)果如下:
方法二:使用兩層for循環(huán)嵌套
代碼示例如下:
//需要注意對于1-20階乘結(jié)果已經(jīng)超出了int能夠接收的范圍 // 故用double類型 //1.遍歷獲取每一個(gè)數(shù)字[1-20] //2.對每一個(gè)數(shù)進(jìn)行階乘 //3.對每個(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的使用場景 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é)果如下:
編者注:以上對本小題的代碼編寫的多種方法,歡迎大家收藏借鑒并轉(zhuǎn)發(fā);
總結(jié)
到此這篇關(guān)于C語言求階乘之和的三種實(shí)現(xiàn)方法的文章就介紹到這了,更多相關(guān)C語言求階乘之和內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
華為云開發(fā)工具CodeArts IDE for C/C++開發(fā)使用指南
CodeArts IDE是一個(gè)集成開發(fā)環(huán)境(IDE),它提供了開發(fā)語言和調(diào)試服務(wù),本文主要介紹了華為云開發(fā)工具CodeArts IDE for C/C++ 開發(fā)使用指南,感興趣的可以了解一下2023-08-08C++ const的使用及this指針常方法(面試最愛問的this指針)
這篇文章主要介紹了C++ const的使用,this指針,常方法(面試最愛問的this指針),本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-04-04c語言實(shí)現(xiàn)通訊錄管理系統(tǒng)詳細(xì)實(shí)例
這篇文章主要給大家介紹了關(guān)于c語言實(shí)現(xiàn)通訊錄管理系統(tǒng)的相關(guān)資料,通訊錄管理系統(tǒng)是一種常見的應(yīng)用程序,可以用來管理聯(lián)系人的信息,包括姓名、電話號碼、地址等,需要的朋友可以參考下2023-07-07淺析C/C++中的可變參數(shù)與默認(rèn)參數(shù)
C支持可變參數(shù)的函數(shù),這里的意思是C支持函數(shù)帶有可變數(shù)量的參數(shù),最常見的例子就是我們十分熟悉的printf()系列函數(shù)。我們還知道在函數(shù)調(diào)用時(shí)參數(shù)是自右向左壓棧的2013-09-09C/C++中for語句循環(huán)用法以及練習(xí)舉例
for語句是一種循環(huán)語句,它是對while語句的推廣,下面這篇文章主要給大家介紹了關(guān)于C/C++中for語句循環(huán)用法以及練習(xí)舉例的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-03-03C++數(shù)據(jù)結(jié)構(gòu)之list詳解
list是一種序列式容器。list容器完成的功能實(shí)際上和數(shù)據(jù)結(jié)構(gòu)中的雙向鏈表是極其相似的,list中的數(shù)據(jù)元素是通過鏈表指針串連成邏輯意義上的線性表,也就是list也具有鏈表的主要優(yōu)點(diǎn),即:在鏈表的任一位置進(jìn)行元素的插入、刪除操作都是快速的2021-11-11