博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
bzoj3174【TJOI2013】解救小矮人
阅读量:6584 次
发布时间:2019-06-24

本文共 1425 字,大约阅读时间需要 4 分钟。

3174: [Tjoi2013]解救小矮人

Time Limit: 1 Sec  
Memory Limit: 128 MB
Submit: 573  
Solved: 293
[ ][ ][ ]

Description

一群小矮人掉进了一个非常深的陷阱里,因为太矮爬不上来,于是他们决定搭一个人梯。即:一个小矮人站在还有一小矮人的 肩膀上。知道最顶端的小矮人伸直胳膊能够碰到陷阱口。

对于每个小矮人,我们知道他从脚到肩膀的高度Ai,而且他的胳膊长度为Bi。陷阱深度为H。假设我 们利用矮人1,矮人2。矮人3,。。

。矮人k搭一个梯子,满足A1+A2+A3+....+Ak+Bk>=H,那么矮人k就能够离开陷阱逃跑了,一 旦一个矮人逃跑了,他就不能再搭人梯了。

我们希望尽可能多的小矮人逃跑, 问最多能够使多少个小矮人逃跑。

Input

第一行一个整数N, 表示矮人的个数。接下来N行每一行两个整数Ai和Bi,最后一行是H。(Ai。Bi,H<=10^5)

Output

一个整数表示对多能够逃跑多少小矮人

Sample Input

例子1

2
20 10
5 5
30

例子2
2
20 10
5 5
35

Sample Output

例子1
2

例子2
1

HINT

数据范围

30%的数据 N<=200
100%的数据 N<=2000

贪心+DP

感性地理解一下。a[i]+b[i]较大的小矮人逃跑的能力更强。所以我们要先让a[i]+b[i]小的人尽可能先逃跑。

于是能够想到按a[i]+b[i]从小到大排序,然后贪心计算。但这个贪心显然是有问题的。所以我们考虑用DP解决贪心的不足。

贪心的不足之处在于当前的小矮人的a[i]还会对后面的小矮人产生影响。所以我们能够令f[i]表示逃跑了i个小矮人剩余a[i]和的最大值。

在更新f数组的同一时候也就计算出了答案。

注意:f数组要逆向更新。

#include
#include
#include
#include
#include
#include
#define F(i,j,n) for(int i=j;i<=n;i++)#define D(i,j,n) for(int i=j;i>=n;i--)#define ll long long#define maxn 2005using namespace std;int n,h,ans,f[maxn];struct data{int x,y;}a[maxn];inline int read(){ int x=0,f=1;char ch=getchar(); while (ch<'0'||ch>'9'){if (ch=='-') f=-1;ch=getchar();} while (ch>='0'&&ch<='9'){x=x*10+ch-'0';ch=getchar();} return x*f;}inline bool cmp(data a,data b){ return a.x+a.y
=h) f[j+1]=max(f[j+1],f[j]-a[i].x); if (f[ans+1]>=0) ans++; } printf("%d\n",ans); return 0;}

转载地址:http://tpxno.baihongyu.com/

你可能感兴趣的文章
20135306第十四周学习总结
查看>>
AutoMapper 5.0-升级指南
查看>>
DCOM中的APPID的用处,以及RemoteServerName的传递问题
查看>>
MYSQL的服务不见了
查看>>
去哪儿网支付系统架构演进全历程阅读心得
查看>>
需求分析及对IT行业创新的理解
查看>>
Spring MVC 处理静态资源不能访问问题
查看>>
Toad常用快捷键
查看>>
hdu 1022 Train Problem I(栈)
查看>>
ZooKeeper学习第一期---Zookeeper简单介绍
查看>>
找众数
查看>>
usaco Scrambled Letters
查看>>
git不能先commit后再pull
查看>>
酒店之王 最大流
查看>>
【模板】矩阵加速(数列) 矩阵快速幂
查看>>
[转载]网络流ISAP算法的简单介绍
查看>>
Extjs5项目进行中:布局(一)
查看>>
Linux下python默认版本切换成替代版本
查看>>
函数生成器和生成器表达式
查看>>
c#局域网文件搬移
查看>>