#include<stdio.h>
#include<math.h>
#include "stdlib.h"
void f(long n)
{printf("%f\t", pow(n,3));
printf("%lf\t", pow(n,3));
printf("%ld\t", (long)pow(n,3));
printf("结果是:%I64d\t",(long long int )pow(n,3));
printf("%d\n", (int)pow(n,3));
}
main()
{long i=5;
printf("%f\t", pow(5,3));
printf("%lf\t", pow(5,3));
printf("%ld\t", (long)pow(5,3));
printf("结果是:%I64d\t",(long long int )pow(5,3));
printf("%d\n", (int)pow(5,3));
system("pause");
printf("%f\t", pow(i,3));
printf("%lf\t", pow(i,3));
printf("%ld\t", (long)pow((int)i,3));
printf("结果是:%I64d\t",(long long int )pow(i,3));
printf("%d\n", (int)pow(i,3));
system("pause");
f(i);
system("pause");
}
这个程序为什么只有前一个输出答案正确,后面的都不正确呢?
我想问的是为什么只有第一组输出语句pow(5,3)输出结果为125,后面二组,输出类型不为实型的时候输出结果为124?
pow()函数用来求x的y次幂,x、y及函数值都是double型 ,其原型为:double pow(double x, double y)。
实例代码如下:
#include<stdio.h>
#include<math.h>
void main()
{
double x = 2, y = 10;
printf("%f\n",pow(x, y));
return 0;
}
扩展资料:
在调用pow函数时,可能导致错误的情况:
如果底数 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。
参考资料: