C++中pow函数

这个函数在头文件中是这样定义的:longdoublepow(longdouble,int)”“floatpow(float,int)”和“doublepow(double... 这个函数在头文件中是这样定义的:long double pow(long double,int)”“float pow(float,int)”和
“double pow(double,int)” ,但为什么pow(2,0.5)不符合以上三种情况编译可以通过而pow(2,1)却无法编译通过?
展开
 我来答
很路人
2012-10-27 · TA获得超过155个赞
知道小有建树答主
回答量:139
采纳率:0%
帮助的人:114万
展开全部
2类型是整型,0.5属于浮点数,而你的函数声明里面第一个参数是浮点数,第二个参数是整型的,
int转float、double可以隐式转换,编译器允许这种转换,但是float、double不能隐式转换成int,这样可能会造成数据丢失,编译器不允许,除非你强制转换
孟羽然
2018-07-21 · TA获得超过2976个赞
知道小有建树答主
回答量:1308
采纳率:70%
帮助的人:573万
展开全部
printf("%f\n", pow(2,3));
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
暗影之王01
2015-05-30 · TA获得超过5.6万个赞
知道大有可为答主
回答量:2万
采纳率:29%
帮助的人:4657万
展开全部
在VC++6.0中原型为double pow( double x, double y );
头文件:cmath
功能:计算x的y次幂。
返回值:x不能为负数且y为小数,或者x为0且y小于等于0,返回幂指数的结果。
返回类型:double型,int,float会给与警告!
举例:
#include<math.h>
#include<stdio.h>
int main(void)
{
doublex=2.0,y=3.0;
printf("%lfraisedto%lfis%lf\n",x,y,pow(x,y));
return0;
}
C++提供以下几种pow函数的重载形式:
double pow(double X,int Y);
float pow(float X,float Y);
float pow(float X,int Y);
long double pow(long double X,long double Y);
long double pow(long double X,int Y);
使用的时候应合理设置参数类型,避免有多个“pow”实例与参数列表相匹配的情况。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 2条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式