解题思路:
注意事项:
参考代码:
#include <cstdio>
#include <vector>
#include <queue>
using namespace std;
int main()
{
priority_queue<int,vector<int>,greater<int> >i;
int n;
scanf("%d",&n);
int x;
while(n --)
{
scanf("%d",&x);
i.push(x);
}
int y;
int sum=0;
while(1)
{
if(i.size()==1)
break;
x=i.top();
i.pop();
y=i.top();
i.pop();
sum+=x+y;
i.push(x+y);
}
printf("%d",sum);
return 0;
}
0.0分
0 人评分
人见人爱A+B (C语言代码)浏览:664 |
P1001 (C语言代码)浏览:836 |
C二级辅导-阶乘数列 (C语言代码)浏览:736 |
C语言程序设计教程(第三版)课后习题5.4 (C语言代码)浏览:552 |
WU-输出正反三角形 (C++代码)浏览:1099 |
DNA (C语言描述,数据结构)浏览:909 |
C语言程序设计教程(第三版)课后习题6.8 (C++代码)浏览:614 |
用筛法求之N内的素数。 (C语言代码)浏览:890 |
C语言程序设计教程(第三版)课后习题8.8 (C语言代码)浏览:583 |
1024题解浏览:879 |