UVA11136Hoax or what( multiset的应用)
Posted zhaop
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了UVA11136Hoax or what( multiset的应用)相关的知识,希望对你有一定的参考价值。
题意:n天,每天往一个箱子里放m个数,放完之后取最大的Max和最小的min做差,并把这两个数去掉,求n天之后的和
multiset 和 set的原理是相似的,multiset可以存多个相同的数,而set都是唯一的,同时都是从小到大排列
set还有lower_bound(x) {返回 第一个大于或者等于x的位置} 和 upper_bound(x) { 返回第一个大于x的位置 }
#include <iostream> #include <set> #include <algorithm> #include <cstring> #include <cstdio> using namespace std; multiset<int> s; int main() { int n,m; while(scanf("%d", &n) != EOF && n) { s.clear(); long long ans = 0; int minn,maxn; for(int i = 1; i <= n; i++) { scanf("%d", &m); for(int j = 1; j <= m; j++) { int thing; scanf("%d", &thing); s.insert(thing); } if(s.size() > 0) { multiset<int>::iterator it; it = s.end(); it--; maxn = *it; s.erase(it); // 本来这里写成了s.erase(maxn),错误,应为会把所有的maxn都删除,这里只要删除一个 it = s.begin(); minn = *it; //如果最后只剩下一个数,既是最大又是最小 if(s.size() > 0) { it = s.begin(); s.erase(it); } ans += maxn - minn; } } printf("%lld\n", ans); } return 0; }
以上是关于UVA11136Hoax or what( multiset的应用)的主要内容,如果未能解决你的问题,请参考以下文章
UVA11136Hoax or what( multiset的应用)
UVA10056 What is the Probability概率
UVA10056 - What is the Probability ?(概率)
What Goes Up UVA - 481 LIS+打印路径 模板