c++ pow函数问题

#include<iostream>#include<cmath>usingnamespacestd;intmain(){intx;cin>>x;cout<<pow(1.... #include<iostream>
#include<cmath>
using namespace std;
int main()
{
int x;
cin>>x;
cout<<pow(1.0*2011,1.0*x)<<endl;
return 0;
}
这个程序是计算2011的x次方,我试了,如果输入1,输出2011,但输入2,会出现4.04412e+006。是什么情况啊?
展开
 我来答
小挤挤dcLm
2014-08-26 · TA获得超过105个赞
知道答主
回答量:101
采纳率:0%
帮助的人:50.4万
展开全部
#include<iostream>
using namespace std;
int main()
{
cout<<"请输入两个数,第一个数为底,第二个为次数。计算N次方问题。"<<endl;
double a;
double b;
double c;
cin>>a;//粗心呐,a,b都没有
cin>>b;//初始化值
double c = pow(a,b);
c = pow(a, b);
cout<<a<<"的"<<b<<"次方是"<<c<<endl;
system("pause");
return 0;
}
追问
不用cmath库吗
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
小卒小丁丁
推荐于2016-11-20 · TA获得超过146个赞
知道小有建树答主
回答量:106
采纳率:100%
帮助的人:117万
展开全部
#include<iostream>
#include<cmath>
using namespace std;
int main()
{
int x;
cin>>x;
cout<<(int)pow(1.0*2011,1.0*x)<<endl;
return 0;
}

上面代码没有问题的,但是你要明白为什么,还是精度问题,你的代码返回是双精度。这个代码你如果输入3你会发现内存溢出。  所以一般用这个函数都会重载一下

本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
xx_lyq00
2014-08-26 · TA获得超过4140个赞
知道大有可为答主
回答量:1794
采纳率:84%
帮助的人:815万
展开全部
结果用double类型输出了,
你试下,(int)pow 这样输出,
更多追问追答
追问
不行啊,只能是double型的,int型的提示编译错误
追答
cout << (int)pow((double)2011, (double)2) << endl;
我这边是可以的。
不过pow的返回值是double或者float类型,精度会有丢失
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式