C语言pow函数问题
为什么会这样,还有,pow函数算出来的值一定要用double类型的值储存吗,用int型可不可以?...
为什么会这样,还有,pow函数算出来的值一定要用double类型的值储存吗,用int型可不可以?
展开
3个回答
展开全部
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。
参考资料:
展开全部
用int存储pow函数的结果,或者说用int保存doublue数值,当然是可以的。但要明白,这会造成数值溢出、精度损失这些问题。
你的运行结果不是用或者不用int变量存储导致的,实际上显示结果只与调用printf这个函数时的参数有关系。建议你仔细了解一下printf函数的细节。
你的运行结果不是用或者不用int变量存储导致的,实际上显示结果只与调用printf这个函数时的参数有关系。建议你仔细了解一下printf函数的细节。
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
一、double类型必须要用%f或%lf输出,否则会影响到其后的所有变量的值!
二、pow函数返回值类型是double类型,当不需要小数时,且,未超出整数范围时,可以存储到int类型中
二、pow函数返回值类型是double类型,当不需要小数时,且,未超出整数范围时,可以存储到int类型中
更多追问追答
追问
是说如果前面计算错误后面都会错?
追答
在输出时,如果中间一个不合规,后面的就全错了!
因为printf()在输出时,是根据格式串去读取后面的变量内存位置,不同变量内存偏移是不同的。所以,一个错,导致其它全错。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询