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!=1
else 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语言阶乘编程题,C语言编程题:阶乘计算的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 基于51单片机的温度甲烷监测报警串口上报
- 下一篇: linux小主机玩法,遗传算法有好多有趣