标签:span 合成 while nyoj iostream 开始 idt style 优先
内存限制:64MB
时间限制:3000ms
Special Judge: No
accepted:8
submit:62
第一行输入整数N(0<N<=10)表示测试数据组数。接下来每组测试数据输入包括两行,第一行是一个整数n(1<=n<=12000),表示果子的种类数。第二行包含n个整数,用空格分隔,第i个整数ai(1<=ai<=20000)是第i种果子的数目。
每组测试数据输出包括一行,这一行只包含一个整数,也就是最小的体力耗费值。
1 3 1 2 9
15
分析:
1、通过优先队列priority_queue<long long, vector<long long>, greater<long long> >可以将数据以升序形式插入队列;
2、由于数据比较大所以要用long long;
3、依次将最小的两个数相加,直到只剩一个数,即就可以得到结果
核心代码:
1 priority_queue<long long, vector<long long>, greater<long long> > my_queue; 2 while(my_queue.size() > 1) 3 { 4 int t = my_queue.top(); 5 my_queue.pop(); 6 t += my_queue.top(); 7 my_queue.pop(); 8 my_queue.push(t); 9 ans += t; // ans即为结果 10 }
C/C++代码实现(AC):
1 #include <iostream> 2 #include <algorithm> 3 #include <cstring> 4 #include <cstdio> 5 #include <cmath> 6 #include <stack> 7 #include <map> 8 #include <queue> 9 #include <set> 10 11 using namespace std; 12 13 int main() 14 { 15 16 int t; 17 scanf("%d", &t); 18 while(t --) 19 { 20 long long n, ans = 0, a, len; 21 scanf("%lld", &n); 22 priority_queue <long long, vector <long long>, greater <long long> > my_pri; 23 //PS:将数据以降序(greater)的形式插入到优先队列中 24 //PS:queue容器不能实现排序数据的插入,priority_queue可以将数据排序后插入 25 for(int i = 0; i < n; ++ i) 26 { 27 scanf("%lld", &a); 28 my_pri.push(a); 29 } 30 while(my_pri.size() > 1) 31 { 32 int a = my_pri.top(); 33 my_pri.pop(); 34 int b = my_pri.top(); 35 my_pri.pop(); 36 my_pri.push(a + b); 37 ans += a + b; 38 } 39 printf("%lld\n",ans); 40 } 41 return 0; 42 }
nyoj 55-懒省事的小明(priority_queue)
标签:span 合成 while nyoj iostream 开始 idt style 优先
原文地址:https://www.cnblogs.com/GetcharZp/p/9107951.html