- 合并果子
- @ 2017-07-29 21:40:39
用优先队列就是方便
#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 条评论
  
  目前还没有评论...