標(biāo)題: 怎么用C語言編寫一個求解冪函數(shù)的程序 [打印本頁]
作者: yonko 時間: 2019-9-20 20:07
標(biāo)題: 怎么用C語言編寫一個求解冪函數(shù)的程序
其實(shí)在絕大多數(shù)C語言編譯器內(nèi)部是有冪函數(shù)這個函數(shù)的,具體的指令是pow(a,b),這個指令實(shí)現(xiàn)的功能就是求解a^b的值,也就是求解a的b次方。
例如,假如我們要求解6的7次方,并把最終的結(jié)果存入變量result,那么我們可以這樣子寫代碼:
include <math.h> //添加數(shù)學(xué)運(yùn)算的頭文件
result= pow(6,7); //求解6的7次方,結(jié)果存入result
但是,如果我們自己要編寫這樣的一個冪函數(shù)該怎么樣編寫呢?
首先我們需要進(jìn)行一些數(shù)學(xué)運(yùn)算方法的思考,假如要求解x^n, n>0且n為整數(shù)。那么應(yīng)當(dāng)是這樣的:
當(dāng)n=0時,x^n=x^0=1;
當(dāng)n=1時,x^n=x^1=x;
當(dāng)n>1時,x^n=x*x…,就是把n個x相乘。這樣就可以得到本案中的冪函數(shù)的計(jì)算流程如圖 1。
圖1.PNG (50.43 KB, 下載次數(shù): 65)
下載附件
2019-9-20 20:06 上傳
在這個程序里面,我們可以使用if條件指令進(jìn)行判斷在n=0,n=1或者n>1的情況下分別進(jìn)行計(jì)算。
特別指出的是,當(dāng)n>1時,用到for循環(huán)函數(shù),n有多大就利用for循環(huán)進(jìn)行(n-1)次的乘法運(yùn)算。(承接軟件開發(fā)業(yè)務(wù)-Q-Q:2531-26-3726)那么編寫的程序如下:
unsigned int pow1(unsigned int x,unsigned int n) //求解冪函數(shù),n為正整數(shù)
{
unsigned char i=0;
if(n==0) x=1; //當(dāng)n=0時,x=1
else
{
if(n==1) x=x; //當(dāng)n=1時,x=x
else //當(dāng)n>1時,用for循環(huán)多次相乘
{
for(i=2;i<=n;i++)
{x=x*x;
}
}
}
return x; //將計(jì)算結(jié)果返回
}
在程序中其他部分調(diào)用函數(shù)pow1就能進(jìn)行冪函數(shù)運(yùn)算。例如求解9的11次方,結(jié)果存入變量result,那么可以像這樣調(diào)用指令pow1進(jìn)行計(jì)算:
result=pow1(9,11);
這樣自己編寫的一個冪函數(shù)就完成了。更多精彩內(nèi)容,盡在公號:yonkotech
| 歡迎光臨 (http://www.raoushi.com/bbs/) |
Powered by Discuz! X3.1 |