1、頭文件:#include
網站建設哪家好,找成都創(chuàng)新互聯公司!專注于網頁設計、網站建設、微信開發(fā)、微信平臺小程序開發(fā)、集團企業(yè)網站建設等服務項目。為回饋新老客戶創(chuàng)新互聯還提供了渾南免費建站歡迎大家使用!
2、原型:
double pow(double x, double y);
pow() 函數用來求 x 的 y 次冪(次方)
pow()用來計算以x 為底的 y 次方值,然后將結果返回。設返回值為 ret,則 ret = xy。
3、舉例如下:
double a = pow(4, 2); ?// 計算4的平方
4、可能導致錯誤的情況:
如果底數 x 為負數并且指數 y 不是整數,將會導致 domain error 錯誤。
如果底數 x 和指數 y 都是 0,可能會導致 domain error 錯誤,也可能沒有;這跟庫的實現有關。
如果底數 x 是 0,指數 y 是負數,可能會導致 domain error 或 pole error 錯誤,也可能沒有;這跟庫的實現有關。
如果返回值 ret 太大或者太小,將會導致 range error 錯誤。
錯誤代碼:
如果發(fā)生 domain error 錯誤,那么全局變量 errno 將被設置為 ?EDOM;
如果發(fā)生 pole error 或 range error 錯誤,那么全局變量 errno 將被設置為 ERANGE。
注意:1、使用pow函數時,需要將頭文件#include包 ? ? ? ? ?含進源文件中。
2、用pow(x,y)的話要用到math.h頭文件。
擴展資料:
1、 三角函數: double sin (double);正弦 ? double cos (double);余弦 ? double tan (double);正切
2 、反三角函數: ? double asin (double); 結果介于[-PI/2, PI/2] ? double acos (double); 結果介于[0, PI] ? double atan (double); 反正切(主值), 結果介于[-PI/2, PI/2] ? double atan2 (double, double); 反正切(整圓值), 結果介于[-PI/2, PI/2]
3 、雙曲三角函數: ? double sinh (double); ? double cosh (double); ? double tanh (double);
4 、指數與對數: ? double exp (double); ? double sqrt (double);開平方 ? double log (double); 以e為底的對數 ? double log10 (double);以10為底的對數 ? double pow(double x, double y);計算以x為底數的y次冪 ? float powf(float x, float y); 功能與pow一致,只是輸入與輸出皆為浮點數
5 、取整: ? double ceil (double); 取上整 ? double floor (double); 取下整
6 、絕對值: ? double fabs (double);求絕對值 ? double cabs(struct complex znum) ;求復數的絕對值
7 、標準化浮點數: ? double frexp (double f, int *p); 標準化浮點數, f = x * 2^p, 已知f求x, p ( x介于[0.5, 1] ) ? double ldexp (double x, int p); 與frexp相反, 已知x, p求f
8 、取整與取余: ? double modf (double, double*); 將參數的整數部分通過指針回傳, 返回小數部分 ? double fmod (double, double); 返回兩參數相除的余數
9 、其他: ? double hypot(double x, double y);已知直角三角形兩個直角邊長度,求斜邊長度 ? double ldexp(double x, int exponent);計算x*(2的exponent次冪) ? double poly(double x, int degree, double coeffs [] );計算多項式 ? nt matherr(struct exception *e);數學錯誤計算處理程序
1、新建一個c語言的工程文件,引入頭文件,這里先定義一個poewer函數處理x的y次方的計算,定義兩個參數n和k,分別表示輸入的數和要求的次方數:
2、在poewer函數中藥考慮k次方為1和0的情況,之后用遞歸的方式將n乘以不斷減小的k即刻完成n次方的計算。之后在主函數定義輸入的數據,用scanf函數接受值,在調用power函數計算,最后輸出結果即可:
3、運行程序,首先輸入數字5,按下回車,接著輸入數字6然后回車,最終程序打印出了5的6次方的結果。以上就是用C語言求X的Y次方的演示:
C語言中表達n次方可以用pow函數。
函數原型:double pow(double x, double y)
功 能:計算x^y的值
返 回 值:計算結果
舉例:
double a;a = pow(3.14, 2); // 計算3.14的平方,并將結果保存在變量a中
注:使用pow函數必須將頭文件#includemath.h包含進源文件中
C語言中計算一個數的N次方可以用庫函數pow來實現。函數原型:double pow(double x, double y)。
代碼如下:
#include stdio.h
#include math.h
int main( )
{ ?
printf("%f",pow(x,y));
return 0;
}
注:使用pow函數時,需要將頭文件#includemath.h包含進源文件中。、
擴展資料:
其他方法表示一個數的n次方:
#include stdio.h
int main( )
{ ? ?int i,k = n;? for(i = 1;i n;i++)
{? ? k *= 2;
}?
printf("%d",k);
return 0;
}
思路:定義一個函數fun(x,n)求x的n次方,即進行n次for循環(huán)執(zhí)行x的累成,主函數調用fun函數。
參考代碼:
#include?stdio.h
int?fun(int?x,int?n){
int?s=1;
while(n--){
s*=x;
}
return?s;
}?
int?main()
{
int?x=2,y=10;
printf("%d\n",fun(2,10));
return?0;
}
/*
運行結果:求2的10次方?
1024
*/
C語言中計算x的n次方可以用庫函數pow來實現。函數原型:doublepow(doublex,doublen)。
具體的代碼如下:
#includestdio.h
#includemath.h
intmain()
{
printf("%f",pow(x,n));
return0;
}
注:使用pow函數時,需要將頭文件#includemath.h包含進源文件中。
擴展資料:
使用其他的方法得到x的n次方:
#includestdio.h
doublepower(doublex,intn);
main()
{
doublex;
intn;
printf("Inputx,n:");
scanf("%lf,%d",x,n);
printf("%.2lf",power(x,n));
}
doublepower(doublex,intn)
{
doublea=1.0;
inti;
for(i=1;i=n;i++)
a*=x;
returna;
}