bzoj4977 跳伞求生——贪心
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=4977
今天讲的贪心题,真神奇啊;
首先,要得到尽量多选队友的解;
把队友按 a[i] 从小到大排序,敌人按 b[i] 从小到大排序,然后对于每个队友,选择能攻击的、收益最多的敌人;
如果没有能攻击的敌人,就把之前最小的一个队友踢掉代替,能使答案更优;
但尽量多选队友不一定是最终的最优答案,因为有些价值很小(为负)的敌人不如不选;
所以需要调整,很妙的做法,就是直接踢掉最小的队友和收益最小的敌人,那么剩下的队友和敌人也一定可以配对,过程中取最优解;
于是去写了,然而秒WA,自己码力好弱啊,打击...
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<queue>
using namespace std;
typedef long long ll;
int const maxn=1e5+,inf=1e9;
int n,m,a[maxn];
ll ans;
bool vis[maxn],out[maxn];
struct N{
int b,c,bh;
bool operator < (const N &y) const
{
return c-b<y.c-y.b;//priority_queue大根堆
}
}p[maxn],t[maxn];
priority_queue<N>qen;
priority_queue<int>q2;
priority_queue<int>q;
bool cmp(N x,N y){return x.b<y.b;}
int main()
{
scanf("%d%d",&n,&m);
for(int i=;i<=n;i++)scanf("%d",&a[i]);
for(int i=;i<=m;i++)scanf("%d%d",&p[i].b,&p[i].c);
sort(a+,a+n+); sort(p+,p+m+,cmp);
for(int i=;i<=m;i++)p[i].bh=i;
int j=,pr=;
for(int i=;i<=n;i++)
{
while(p[j].b<=a[i]) {qen.push(p[j]); j++;}
if(!qen.size()) {t[i]=t[pr]; out[pr]=; pr++;}
else {t[i]=qen.top(); vis[t[i].bh]=; qen.pop();}
}
for(int i=;i<=n;i++)
if(!out[i])ans+=a[i]-t[i].b+t[i].c;
for(int i=;i<=m;i++) if(vis[i])q2.push(p[i].b-p[i].c);
for(int i=;i<=n;i++) if(!out[i])q.push(-a[i]);//
ll tmp=ans;
while(q.size()&&q2.size())
{
int x=-q.top(); q.pop();
int y=-q2.top(); q2.pop();
tmp-=x; tmp-=y;
ans=max(ans,tmp);
}
printf("%lld\n",ans);
return ;
}
囧
看看人家写的简洁优美AC代码:https://blog.csdn.net/dream_lolita/article/details/79302382
然后就模仿着写了;练习码力...
代码如下:
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<queue>
using namespace std;
typedef long long ll;
int const maxn=1e5+;
int n,m,w[maxn],hd,tl;
ll ans,sum;
struct N{
int x,y; bool tp;
bool operator < (const N &b) const
{
if(x==b.x)return tp<b.tp;
else return x<b.x;
}
N(int x=,int y=,bool t=):x(x),y(y),tp(t) {}
}t[maxn<<];
priority_queue<int>q;
priority_queue<int,vector<int>,greater<int> >p;
int main()
{
scanf("%d%d",&n,&m);
for(int i=,x;i<=n;i++)scanf("%d",&t[i].x);
for(int i=,x,y;i<=m;i++)
{
n++;
scanf("%d%d",&x,&y);
t[n]=N(x,y-x,);
}
sort(t+,t+n+);
hd=;
for(int i=;i<=n;i++)
{
if(t[i].tp)q.push(t[i].y);
else
{
if(!q.size())
{
if(hd<=tl)
{
int tmp=w[hd]; hd++;
sum+=t[i].x-tmp;
w[++tl]=t[i].x;
}
}
else
{
int tmp=q.top(); q.pop();
sum+=t[i].x+tmp;
p.push(tmp);//tmp被使用过
w[++tl]=t[i].x;
}
}
}
ans=sum;
for(int i=hd;i<=tl;i++)
{
sum-=w[i]+p.top(); p.pop();
ans=max(ans,sum);
}
printf("%lld\n",ans);
return ;
}
bzoj4977 跳伞求生——贪心的更多相关文章
- [bzoj4977]跳伞求生<贪心>
题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=4977 这是八月月赛的一道题,月赛的时候和同学讨论了一下,最后由一位叫二哥的大佬率先AC,用 ...
- BZOJ4977[Lydsy1708月赛]跳伞求生——贪心+堆+模拟费用流
题目链接: 跳伞求生 可以将题目转化成数轴上有$n$个人和$m$个房子,坐标分别为$a_{i}$和$b_{i}$,每个人可以进一个他左边的房子,每个房子只能进一个人.每个房子有一个收益$c_{i}$, ...
- BZOJ4977 跳伞求生(贪心)
如果现在选定了一些要求消灭的敌人而不考虑积分,显然应该让每个敌人被刚好能消灭他的人消灭.再考虑最大化积分,显然我们应该优先消灭ci-bi大的敌人,所选用的a也应尽量大.于是按ci-bi从大到小排序,用 ...
- BZOJ4977: [[Lydsy1708月赛]跳伞求生(不错的贪心)
4977: [[Lydsy1708月赛]跳伞求生 Time Limit: 5 Sec Memory Limit: 256 MBSubmit: 446 Solved: 142[Submit][Sta ...
- 【刷题】BZOJ 4977 [Lydsy1708月赛]跳伞求生
Description 小Q最近沉迷于<跳伞求生>游戏.他组建了一支由n名玩家(包括他自己)组成的战队,编号依次为1到n.这个游 戏中,每局游戏开始时,所有玩家都会从飞机上跳伞,选择一个目 ...
- BZOJ4977 八月月赛 Problem G 跳伞求生 set 贪心
欢迎访问~原文出处——博客园-zhouzhendong 去博客园看该题解 题目传送门 - BZOJ4977 - 八月月赛 Problem G 题意 小明组建了一支由n名玩家组成的战队,编号依次为1到n ...
- 2018.09.24 bzoj4977: [[Lydsy1708月赛]跳伞求生(贪心+线段树)
传送门 线段树好题. 这题一看我就想贪心. 先把a,b数组排序. 然后我们选择a数组中最大的b个数(不足b个就选a个数),分别贪心出在b数组中可以获得的最大贡献. 这时可以用线段树优化. 然后交上去只 ...
- BZOJ4977: [[Lydsy1708月赛]跳伞求生
传送门 直接贪心 考虑到 \(n\) 个人的贡献都是 \(a_i\),另外 \(m\) 个人的贡献都是 \(c_i-b_i\) 首先 \(a_i>b_j\) 的限制不好做,所以将 \(a,b\) ...
- bzoj 1034 [ZJOI2008]泡泡堂BNB——贪心
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=1034 原来觉得和 bzoj4977跳伞求生 有点像(虽然还没做). 所以对于a[ ]从小到大 ...
随机推荐
- 【译】x86程序员手册18-6.3.1描述符保存保护参数
6.3 Segment-Level Protection 段级保护 All five aspects of protection apply to segment translation: 段转换时会 ...
- Zabbix自带的mysql监控模块
Zabbix自带的mysql监控模块 [root@Cagios zabbix-]# cp conf/zabbix_agentd/userparameter_mysql.conf /usr/local/ ...
- if判断,while循环,for循环
if判断 if判断其实就是让计算机模拟人的判断 if if 条件: 代码1 代码2 代码3 ... # 代码块(同一缩进级别的代码,例如代码1.代码2和代码3是相同缩进的代码,这三个代码组合在一起就是 ...
- Origin C调用NAG库
NAG(Numerical Algorithms Group, www.nag.com)库是一个无与伦比的算法库,它提供的算法可靠.轻便.严谨,覆盖了数学与统计方方面面.最大的缺点就是:它是一个收费的 ...
- Map 键值对 set get delete
- requirejs(模块化)
<script src="../../dist/js/require.js" data-main="../../dist/js/main.js">& ...
- DOM节点的获取
document.getElementById();//id名,在实际开发中较少使用,选择器中多用class id一般只用在顶级层存在 不能太过依赖id document.getElements ...
- 使用Python的Flask框架,结合Highchart,动态渲染图表(Ajax 请求数据接口)
参考链接:https://www.highcharts.com.cn/docs/ajax 参考链接中的示例代码是使用php写的,这里改用python写. 需要注意的地方: 1.接口返回的数据格式,这个 ...
- 一个电商项目的Web服务化改造7:Dubbo服务的调用,4个项目
使用dubbo服务的过程,很简单,和之前学习的WebService完全一样,和本地接口调用也基本一致. dubbo和WebService的区别:我认为dubbo就是封装了WebService,然后提供 ...
- JavaSE 学习笔记之异 常(十)
异 常: 异常:就是不正常.程序在运行时出现的不正常情况.其实就是程序中出现的问题.这个问题按照面向对象思想进行描述,并封装成了对象.因为问题的产生有产生的原因.有问题的名称.有问题的描述等多个属性信 ...