標(biāo)題: 怎么用C語(yǔ)言編寫一個(gè)求解冪函數(shù)的程序 [打印本頁(yè)]
作者: yonko 時(shí)間: 2019-9-20 20:07
標(biāo)題: 怎么用C語(yǔ)言編寫一個(gè)求解冪函數(shù)的程序
其實(shí)在絕大多數(shù)C語(yǔ)言編譯器內(nèi)部是有冪函數(shù)這個(gè)函數(shù)的,具體的指令是pow(a,b),這個(gè)指令實(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
但是,如果我們自己要編寫這樣的一個(gè)冪函數(shù)該怎么樣編寫呢?
首先我們需要進(jìn)行一些數(shù)學(xué)運(yùn)算方法的思考,假如要求解x^n, n>0且n為整數(shù)。那么應(yīng)當(dāng)是這樣的:
當(dāng)n=0時(shí),x^n=x^0=1;
當(dāng)n=1時(shí),x^n=x^1=x;
當(dāng)n>1時(shí),x^n=x*x…,就是把n個(gè)x相乘。這樣就可以得到本案中的冪函數(shù)的計(jì)算流程如圖 1。
圖1.PNG (50.43 KB, 下載次數(shù): 65)
下載附件
2019-9-20 20:06 上傳
在這個(gè)程序里面,我們可以使用if條件指令進(jìn)行判斷在n=0,n=1或者n>1的情況下分別進(jìn)行計(jì)算。
特別指出的是,當(dāng)n>1時(shí),用到for循環(huán)函數(shù),n有多大就利用for循環(huán)進(jìn)行(n-1)次的乘法運(yùn)算。(承接軟件開(kāi)發(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時(shí),x=1
else
{
if(n==1) x=x; //當(dāng)n=1時(shí),x=x
else //當(dāng)n>1時(shí),用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);
這樣自己編寫的一個(gè)冪函數(shù)就完成了。更多精彩內(nèi)容,盡在公號(hào):yonkotech
歡迎光臨 (http://www.torrancerestoration.com/bbs/) |
Powered by Discuz! X3.1 |