Luogu P3619 魔法 【贪心/微扰证明】
题目描述
cjwssb知道是误会之后,跟你道了歉。你为了逗笑他,准备和他一起开始魔法。不过你的时间不多了,但是更惨的是你还需要完成n个魔法任务。假设你当前的时间为T,每个任务需要有一定的限制ti表示只有当你的T严格大于ti时你才能完成这个任务,完成任务并不需要消耗时间。当你完成第i个任务时,你的时间T会加上bi,此时要保证T在任何时刻都大于0,那么请问你是否能完成这n个魔法任务,如果可以,输出+1s,如果不行,输出-1s。
输入输出格式
输入格式:
第一行:一个整数Z,表示有Z个测试点。
对于每个测试点
第一行:一个整数n,T,表示有n个任务,你一开始有T的时间。
接下来n行,每行2个数字,ti与bi
输出格式:
对于每个测试点,输出+1s或者-1s
输入输出样例
1
2 13
1 -9
5 -3
+1s
说明
对于20%的数据,n≤10
对于100%的数据,n≤100,000,Z≤10,ti,T≤100,000,−100,000≤bi≤100,000
By:lantian
观察样例后我们发现,竟然有负数!看起来只能大力贪心了!
大力贪心一番,我们发现我们可以先做所有bi为正的任务,这样我们所拥有的续命时间就会猛增,达到一个人生巅峰!
这部分可以先按ti递增排序,先满足条件的低的任务,步步走上人生巅峰。
bi为正的任务,我们就处理完了。
再来看bi为负的任务,想一想我们好像手足无措、无计可施。不妨考虑一些优雅的、有根据的贪心?
还记得国王游戏吗?那道题我们用到了微扰(邻值交换)的方法,这道题会不会也适用?
什么是微扰?粗糙的理解就是在局部情况下,我们交换两个变量组的值,这里只会改变局部的情况,而整体局面不变。交换后局部情况可能会变得更优或更差,于是我们就可以找出一种排序的根据,再进行贪心便有理有据。关键是交换前后局部情况改变,才能得到正确的关系。

//图片怎么旋转啊!!麻烦各位看官转个头qwq
code
#include<cstdio>
#include<algorithm>
#include<utility> using namespace std; int T,ti,n,tot,cnt;
struct node{
int t,b;
}nega[];
struct Vergil{
int t,b;
}posi[]; bool cmp1(Vergil p,Vergil q)
{
return p.t<q.t;
} bool cmp2(node p,node q)
{
return p.t+p.b>q.t+q.b;
} void clear()
{
for(int i=;i<=cnt;i++) nega[i].t=,nega[i].b=;
for(int i=;i<=tot;i++) posi[i].t=,posi[i].b=;
cnt=,tot=;
} int main()
{
scanf("%d",&T);
while(T--)
{
clear();
bool flag=false;
scanf("%d%d",&n,&ti);
for(int i=;i<=n;i++)
{
int x=,y=;
scanf("%d%d",&x,&y);
if(y>) posi[++tot].t=x,posi[tot].b=y;
else nega[++cnt].t=x,nega[cnt].b=y;
}
sort(posi+,posi+tot+,cmp1); for(int i=;i<=tot;i++)
{
if(ti<=posi[i].t)
{
printf("-1s\n");
flag=true;
break;
}
ti+=posi[i].b;
if(ti<=)
{
printf("-1s\n");
flag=true;
break;
}
}
if(flag) continue; sort(nega+,nega+cnt+,cmp2);
for(int i=;i<=cnt;i++)
{
if(ti<=nega[i].t)
{
printf("-1s\n");
flag=true;
break;
}
ti+=nega[i].b;
if(ti<=)
{
printf("-1s\n");
flag=true;
break;
}
}
if(flag) continue;
printf("+1s\n");
}
return ;
}
注意是严格大于!在这被坑了qwq
Luogu P3619 魔法 【贪心/微扰证明】的更多相关文章
- NOIP2012BLOCKADE贪心思想证明
NOIP2012BLOCKADE贪心思想证明 这道题的做法是二分时间并检验这个时间是否可行.检验的方法要用到贪心思想. 对于不能到根结点的军队应该尽量向根结点走. 如果军队A能走到根结点但到根结点后剩 ...
- [HNOI2015]菜肴制作贪心的证明
[HNOI2015]菜肴制作贪心的证明 先吐槽一句为什么网上都没人证这个东西,我觉得一点也不显然啊... 判环不用说了,现在处理一个DAG.考虑按题意模拟:建反图(边从后选的点连向先选的点),每次找全 ...
- Knapsack I 竟然是贪心,证明啊。。。。
Knapsack I Time Limit: 2000/1000MS (Java/Others) Memory Limit: 128000/64000KB (Java/Others) SubmitSt ...
- Luogu 1583 - 魔法照片 - [简单排序题]
题目链接:https://www.luogu.org/problemnew/show/P1583 题目描述一共有n(n≤20000)个人(以1--n编号)向佳佳要照片,而佳佳只能把照片给其中的k个人. ...
- luogu P2672 推销员 |贪心
题目描述 阿明是一名推销员,他奉命到螺丝街推销他们公司的产品.螺丝街是一条死胡同,出口与入口是同一个,街道的一侧是围墙,另一侧是住户.螺丝街一共有N家住户,第ii家住户到入口的距离为Si米.由于同一栋 ...
- luogu P1650 田忌赛马 |贪心
题目描述 我国历史上有个著名的故事: 那是在2300年以前.齐国的大将军田忌喜欢赛马.他经常和齐王赛马.他和齐王都有三匹马:常规马,上级马,超级马.一共赛三局,每局的胜者可以从负者这里取得200银币. ...
- Luogu P1583 魔法照片
题目描述 一共有n(n≤20000)个人(以1--n编号)向佳佳要照片,而佳佳只能把照片给其中的k个人.佳佳按照与他们的关系好坏的程度给每个人赋予了一个初始权值W[i].然后将初始权值从大到小进行排序 ...
- P3619 魔法
考虑两个任务 \(1\) 和 \(2\),当前时间为 \(T\),两个任务都要完成. 先完成任务 \(1\) 的条件是 \(T>t_1\) 且 \(T+b_1>t_2\),先完成任务 \( ...
- BZOJ1124 [POI2008]枪战Maf[贪心(证明未完成)+拓扑排序]
吐槽:扣了几个小时,大致思路是有了,但是贪心的证明就是不会, 死磕了很长时间,不想想了,结果码代码又不会码.. 深深体会到自己码力很差,写很多行还没写对,最后别人代码全一二十行,要哭了 以下可能是个人 ...
随机推荐
- [Bzoj1069][Scoi2007]最大土地面积(凸包)(旋转卡壳)
1069: [SCOI2007]最大土地面积 Time Limit: 1 Sec Memory Limit: 128 MBSubmit: 3629 Solved: 1432[Submit][Sta ...
- 基于commons-net实现ftp创建文件夹、上传、下载功能
原文:http://www.open-open.com/code/view/1420774470187 package com.demo.ftp; import java.io.FileInputSt ...
- 从头开始学Android之(一)——— Android架构
从事Android开发已经两年多了,最近项目上特别清闲,刚开始时在闲暇的时候都不知道干嘛,整天混日子.有一天突然有个以前同学找到我,说要我帮忙做一个Android的需求,就是在后台截屏(涉及到服务以及 ...
- 拷贝地图 CopyAndOverwriteMap()
private void CopyAndOverwriteMap() { //Get IObjectCopy interface IObjectCopy objectCopy = new Object ...
- iOS用户体验之-modal上下文
iOS用户体验之-modal上下文 何为模态视图,它的作用时聚焦当前.获得用户的注意,用户仅仅有完毕模态的任务才 退出模态视图.否则你将不能运行app的任务,比如,alert view,model v ...
- C# 谁改了我的代码 使用 Resharper 快速做适配器
C# 谁改了我的代码 本文告诉大家一个特殊的做法,可以修改一个字符串常量 我们来写一个简单的程序,把一个常量字符串输出 private const string str = "linde ...
- 【OpenCV新手教程之十四】OpenCV霍夫变换:霍夫线变换,霍夫圆变换合辑
本系列文章由@浅墨_毛星云 出品,转载请注明出处. 文章链接:http://blog.csdn.net/poem_qianmo/article/details/26977557 作者:毛星云(浅墨) ...
- Android 封装实现各种样式对话框
先上图 watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/disso ...
- C控制台密码输入:输入一个字符显示一个星号
要在c控制台中输入一个字符显示一个星号, 则不能用"stdio.h'提供的库函数,因为它们都是带回显的,比如getchar() getchar()用来接收输入的字符串,输入一个字符就回显一个 ...
- python itertools
1 product 1.1 一个generator函数 因此它的返回值是一个iterator,可以用for遍历. 1.2 计算product的参数分类 1.2.1 dict和list 只用了dict的 ...