用C语言程序设计:求x的n次方的函数。

2024-11-06 09:25:39
推荐回答(3个)
回答1:

double pow(double x, double y);

pow()用来计算以x 为底的 y 次方值,然后将结果返回

可能导致错误的情况:

如果底数 x 为负数并且指数 y 不是整数,将会导致 domain error 错误。

如果底数 x 和指数 y 都是 0,可能会导致 domain error 错误,也可能没有;这跟库的实现有关。

如果底数 x 是 0,指数 y 是负数,可能会导致 domain error 或 pole error 错误,也可能没有;这跟库的实现有关。

如果返回值 ret 太大或者太小,将会导致 range error 错误。

错误代码:

如果发生 domain error 错误,那么全局变量 errno 将被设置为  EDOM;

如果发生 pole error 或 range error 错误,那么全局变量 errno 将被设置为 ERANGE。

注意,使用 GCC 编译时请加入-lm。

#include

#include

intmain()

{ printf("7 ^ 3 = %f\n",pow(7.0,3.0));

printf("4.73 ^ 12 = %f\n",pow(4.73,12.0));

printf("32.01 ^ 1.54 = %f\n",pow(32.01,1.54));

return0;}

输出结果:

7 ^ 3 = 343.000000

4.73 ^ 12 = 125410439.217423

32.01 ^ 1.54 = 208.036691

回答2:

double pow(double x, double y);
pow()用来计算以x 为底的 y 次方值,然后将结果返回

回答3:

math.h库里有这个函数,pow(x,n),也可以自己用循环来写

long fun(int x,int n)
{ long p=1; int i;
for (i=1;i<=n;i++)
p*=x;
return p;
}

在主函数main()中,直接调用fun函数即可