C语言pow函数问题

为什么会这样,还有,pow函数算出来的值一定要用double类型的值储存吗,用int型可不可以?... 为什么会这样,还有,pow函数算出来的值一定要用double类型的值储存吗,用int型可不可以? 展开
 我来答
丿MarsHan
2018-12-15 · TA获得超过4921个赞
知道答主
回答量:79
采纳率:0%
帮助的人:43.2万
展开全部

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。

参考资料:

pow函数——百度百科

linnjing
推荐于2017-09-25 · TA获得超过2632个赞
知道大有可为答主
回答量:1230
采纳率:91%
帮助的人:518万
展开全部
用int存储pow函数的结果,或者说用int保存doublue数值,当然是可以的。但要明白,这会造成数值溢出、精度损失这些问题。
你的运行结果不是用或者不用int变量存储导致的,实际上显示结果只与调用printf这个函数时的参数有关系。建议你仔细了解一下printf函数的细节。
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
kaixingui2012
2015-10-29 · TA获得超过4.2万个赞
知道大有可为答主
回答量:1.4万
采纳率:81%
帮助的人:6445万
展开全部
一、double类型必须要用%f或%lf输出,否则会影响到其后的所有变量的值!
二、pow函数返回值类型是double类型,当不需要小数时,且,未超出整数范围时,可以存储到int类型中
更多追问追答
追问
是说如果前面计算错误后面都会错?
追答
在输出时,如果中间一个不合规,后面的就全错了!
因为printf()在输出时,是根据格式串去读取后面的变量内存位置,不同变量内存偏移是不同的。所以,一个错,导致其它全错。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式