首页 > 代码库 > 10-18 noip提高组模拟赛(codecomb)T2贪心
10-18 noip提高组模拟赛(codecomb)T2贪心
T2:找min:一直找最小的那个,直到a[i]-x+1小于0,就找次小的,以此类推;
求max,也是一样的,一直到最大的那个,直到次大的比之前最大的大,就找次大的;
这个模拟,可以用上priority_queue;
#include <cstdio>#include <cstring>#include <algorithm>#include <iostream>#include <queue>using namespace std;const int maxn=1000001;int n,m;int a[maxn];long long minx,maxx;priority_queue<int> q;int main(){ scanf("%d%d",&n,&m); for(int i=1;i<=n;i++){ scanf("%d",&a[i]); q.push(a[i]); } sort(a+1,a+n+1); int temp=1; for(int i=1;i<=m;i++){ int t=q.top(); q.pop(); maxx+=t; q.push(t-1); while(!a[temp]) temp++; minx+=a[temp]; a[temp]--; } cout<<maxx<<" "<<minx; return 0;}
10-18 noip提高组模拟赛(codecomb)T2贪心
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。