一个关于优先队列的c语言问题。

#include<stdio.h>#include<algorithm>#include<math.h>#include<queue>usingnamespacestd;... #include<stdio.h>
#include<algorithm>
#include<math.h>
#include<queue>
using namespace std;
priority_queue<double> q;
int main()
{
int n;
scanf("%d",&n);
for(int i=0;i<n;i++)
{
double val;
scanf("%lf",&val);
q.push(val);
}
for(int i=0;i<n;i++)
{
///printf("%d\n",q.top());
double m=q.top();
q.pop();
double n=q.top();
q.pop();
double v= 2*sqrt(m*n);
q.push(v);
}
printf("%lf\n",q.top());
return 0;
}
求大神看看为啥输出总是0???
展开
 我来答
wchyumo2011
2015-07-10 · TA获得超过2万个赞
知道大有可为答主
回答量:5810
采纳率:79%
帮助的人:2863万
展开全部
第二个循环中少循环一次,最后的队列中才能留下一个值。
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式