还是”stl大法“好

用优先队列就是方便

#include <queue>
#include <iostream>
#include <algorithm>
using namespace std;
int main ()
{
priority_queue<int,vector<int>,greater<int> > pq;//小根堆
int n,x,sum=0;
cin>>n;
for(int i=0;i<n;i++)
{
cin>>x;
pq.push(x);
}
x=0;
while(pq.size()>1)
{
x+=pq.top();pq.pop();
x+=pq.top();pq.pop();
sum+=x;pq.push(x);
x=0;
}
cout<<sum;
return 0;
}

0 条评论

目前还没有评论...

信息

ID
1097
难度
6
分类
贪心 点击显示
标签
递交数
23854
已通过
6310
通过率
26%
被复制
41
上传者