c语言中pow函数出错 c语言里pow函数的用法

C语言pow函数出错?

函数没有问题,这是浮点数精度的问题。就是你所计算的数超过了浮点数的精度范围(不是表示范围)。双精度浮点数小数最后几位有时候会是9996和0004

成都创新互联专注于企业成都营销网站建设、网站重做改版、光山网站定制设计、自适应品牌网站建设、H5技术商城建设、集团公司官网建设、成都外贸网站建设、高端网站制作、响应式网页设计等建站业务,价格优惠性价比高,为光山等各大城市提供网站开发制作服务。

C语言pow函数

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

实例代码如下:

#includestdio.h

#includemath.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函数——百度百科

C语言 请问为什么这儿pow函数会报错?

看错误就知道了,pow函数第一个参数不支持int型的,要么double,要么float要么long double,改成p=pow(2.0,i);吧

C语言pow函数的输出结果不正确

double r,n,p;// 定义为 int n 对应下面%d

scanf("%f%d", r,n);//double 型 格式输入 %lf

r=r+1;

p=pow(r,n);

printf("%f\n", p);//改为%lf

这里你 用float型 输入输出double型数据 会造成数据缺失


当前标题:c语言中pow函数出错 c语言里pow函数的用法
标题链接:http://azwzsj.com/article/dogocsi.html