C语言编程题:阶乘计算
生活随笔
收集整理的這篇文章主要介紹了
C语言编程题:阶乘计算
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
一.題目:求20!的結果
?
描述:將數學概念的迭代關系式i!=(i-1)!*i轉換為計算機循環意義上的迭代關系式——用新的變量存儲新值(乘積),并不斷由舊值遞推出變量的新值。求n!的函數fanc(n)的處理對象時一個int型數據,函數的返回值應該用浮點類型(double或float)表示,因此函數的首部可以確定為double fanc(int n)。
?
輸入:輸入的是n的大小,直接通過main函數調用fanc(n)函數得出結果
?
輸出:輸出n!=f
#include "stdio.h" //求n!的函數 double fac(int n) {int i;double f=1;if(n>0){for(i=1;i<=n;i++)f=f*i;}else if(n==0)f=1;//根據階乘的定義 0!=1else if(n<0)f=-1;//如果n為負數,則返回-1,表示錯誤return f; }int main() {int n;double f;//用來存放最后的結果printf("Input n:");scanf("%d",&n);f=fac(n);//(int)f;if(f==-1){printf("參數輸入錯誤!!\n");}else {printf("%d!的結果是=%e\n",n,f);}return 0; }?
編程技巧與注意事項:
1.編程注意考慮函數的健壯性,要盡量優化函數,是一個獨立函數具有良好的封裝性和相對完整的功能。如上面再fac(n)內增加對0!和對錯誤參數的處理。
2.在主函數和調用函數中同時用同一個符號定義和使用變量是合法的。
總結
以上是生活随笔為你收集整理的C语言编程题:阶乘计算的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 【bzoj1911】 Apio2010—
- 下一篇: http详解 请求报文格式和响应报文格