为什么自己实现一个pow()函数呢?昨天在Linux操作系统中调用这一个函数时,一直报错,也没有查找到具体的原因。故心血来潮实现这一函数功能。
函数所在头文件:
在"math.h"头文件中
函数原型
double pow (doublebase,double exponent);
函数功能
求base的exponent幂,即求某个数的多少次幂
函数参数
base :基数(double类型)
exponent :幂值,即进行多少次幂的值
函数返回值
如果成功执行,返回求得某个数的多少次幂的值;否则,返回错误。
实例一:pow()函数简单使用
#include<stdio.h>
#include<math.h> int main(void)
{
double value1 = pow(2.0,3.0);
printf("value1 = %f\n", value1); double value2 = pow(2.22,3.0);
printf("value2 = %f\n", value2); double value3 = pow(5.21,4.11);
printf("value3 = %f\n", value3); return0;
}
运行结果:
实例二:pow()函数实现代码
#include<stdio.h>
#include<math.h>
//实现pow()函数
double mypow(double num,double n)
{
double value =;
int i =;
if(n ==)
{
value =;
}
else
{
while(i++<= n)
{
value *= num;
}
}
return value;
} int main(void)
{
double value1 = mypow(2.0,3.0);
printf("value1 = %f\n", value1); double value2 = mypow(2.22,3.0);
printf("value2 = %f\n", value2); double value3 = mypow(5.21,4.11);
printf("value3 = %f\n", value3); return0;
}
运行结果
操作注意:
可能导致错误的情况:
- 如果底数 x 为负数并且指数 y 不是整数,将会导致 domain error 错误。
- 如果底数 x 和指数 y 都是 0,可能会导致 domain error 错误,也可能没有;这跟库的实现有关。
- 如果底数 x 是 0,指数 y 是负数,可能会导致 domain error 或 pole error 错误,也可能没有;这跟库的实现有关。
- 如果返回值 ret 太大或者太小,将会导致 range error 错误。
在使用"math.h"头文件里面的库函数时,在Linux系统上进行GCC编译时,需要在命令后面加上"-lm"(链接库函数的文件);否则会报错。