pow函数(数学次方)在c语言的用法,两种编写方法实例( 计算1/1-1/2+1/3-1/4+1/5 …… + 1/99 - 1/100 的值)

时间:2023-03-08 20:15:50
pow函数(数学次方)在c语言的用法,两种编写方法实例( 计算1/1-1/2+1/3-1/4+1/5 …… + 1/99 - 1/100 的值)

头文件:#include <math.h>

pow() 函数用来求 x 的 y 次幂(次方),x、y及函数值都是double型 ,其原型为:
    double pow(double x, double y);

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

可能导致错误的情况:
如果底数 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。
Math.pow(底数,几次方)
如:double a=2.0;
    double b=3.0;
double c=Math.pow(a,b);
就是2的三次方是多少;
c最终为8.0;


计算1/1-1/2+1/3-1/4+1/5 …… + 1/99 - 1/100 的值。

分别用了两种方法计算,第一种比较简单用了两个for循环,第二个采用pow函数,用了一个for循环:

第一个程序:

 #include <stdio.h>
#include <stdlib.h>
int main()
{
//将分成两部分进行
int i;
double j = 0.0, k = 0.0;
int a;
double b = 0.0, c = 0.0;
double d;
for (i = ; i <= ; i++){
j =1.0/ (2.0 * i - 1.0);
k = k + j; }
for (a = ; a <= ; a++){
b = -1.0/(2.0 * a);
c = c + b; }
d = k + c;
printf("%f\n", d);
system("pause");
return ;
}

pow函数(数学次方)在c语言的用法,两种编写方法实例( 计算1/1-1/2+1/3-1/4+1/5 …… + 1/99 - 1/100 的值)

第二个程序:

 #include<stdio.h>
#include<math.h>
#include<stdlib.h>
int main()
{
int i;
double sum = 0.0, temp = 0.0;
for (i = ; i <= ; i++)
{
temp = pow(-, i + );
sum = sum + temp * / i;
}
printf("sum is %f\n", sum);
system("pause");
return ;
}

运行结果一样,也是0.688172.