BZOJ3174:[TJOI2013]拯救小矮人(DP)
Description
一群小矮人掉进了一个很深的陷阱里,由于太矮爬不上来,于是他们决定搭一个人梯。即:一个小矮人站在另一小矮人的 肩膀上,知道最顶端的小矮人伸直胳膊可以碰到陷阱口。对于每一个小矮人,我们知道他从脚到肩膀的高度Ai,并且他的胳膊长度为Bi。陷阱深度为H。如果我 们利用矮人1,矮人2,矮人3,。。。矮人k搭一个梯子,满足A1+A2+A3+....+Ak+Bk>=H,那么矮人k就可以离开陷阱逃跑了,一 旦一个矮人逃跑了,他就不能再搭人梯了。
我们希望尽可能多的小矮人逃跑, 问最多可以使多少个小矮人逃跑。
Input
Output
Sample Input
2
20 10
5 5
30
样例2
2
20 10
5 5
35
Sample Output
2
样例2
1
HINT
数据范围
30%的数据 N<=200
100%的数据 N<=2000
Solution
证明戳这里吧
$f[i]$表示跑了$i$个人后剩下的能组成的人梯的最高高度
Code
#include<iostream>
#include<cstring>
#include<cstdio>
#include<algorithm>
#define N (2009)
using namespace std; struct Node
{
int x,y;
bool operator < (const Node &a) const
{
return x+y<a.x+a.y;
}
}a[N];
int n,h,f[N],ans,sum; int main()
{
scanf("%d",&n);
for (int i=; i<=n; ++i)
scanf("%d%d",&a[i].x,&a[i].y),sum+=a[i].x;
scanf("%d",&h);
sort(a+,a+n+);
memset(f,-,sizeof(f));
f[]=sum;
for (int i=; i<=n; ++i)
for (int j=ans; j>=; --j)
{
if (f[j]+a[i].y>=h)
f[j+]=max(f[j+],f[j]-a[i].x);
if (f[ans+]>=) ans++;
}
printf("%d\n",ans);
}
BZOJ3174:[TJOI2013]拯救小矮人(DP)的更多相关文章
- BZOJ3174. [TJOI2013]拯救小矮人(dp)
		题目链接 https://www.lydsy.com/JudgeOnline/problem.php?id=3174 题解 其实此题并不需要那么多YY的部分. 我们考虑若干个小矮人逃出的顺序.若跳出的 ... 
- BZOJ3174 Tjoi2013 拯救小矮人(贪心+DP)
		传送门 Description 一群小矮人掉进了一个很深的陷阱里,由于太矮爬不上来,于是他们决定搭一个人梯.即:一个小矮人站在另一小矮人的 肩膀上,知道最顶端的小矮人伸直胳膊可以碰到陷阱口.对于每一个 ... 
- bzoj3174 [Tjoi2013]拯救小矮人
		Description 一群小矮人掉进了一个很深的陷阱里,由于太矮爬不上来,于是他们决定搭一个人梯.即:一个小矮人站在另一小矮人的 肩膀上,知道最顶端的小矮人伸直胳膊可以碰到陷阱口.对于每一个小矮人, ... 
- BZOJ3174 TJOI2013 拯救小矮人 贪心、DP
		传送门 原问题等价于:先给\(n\)个人排好顺序.叠在一起,然后从顶往底能走即走,问最多能走多少人 注意到一个问题:如果存在两个人\(i,j\)满足\(a_i + b_i < a_j + b_j ... 
- bzoj千题计划208:bzoj3174: [Tjoi2013]拯救小矮人
		http://www.lydsy.com/JudgeOnline/problem.php?id=3174 按a+b从小到大排序,a+b小的在上面,先考虑让它逃出去 正确性不会证 感性理解一下,最后一个 ... 
- 【BZOJ-3174】拯救小矮人       贪心 + DP
		3174: [Tjoi2013]拯救小矮人 Time Limit: 1 Sec Memory Limit: 128 MBSubmit: 686 Solved: 357[Submit][Status ... 
- BZOJ_3174_[Tjoi2013]拯救小矮人_贪心+DP
		BZOJ_3174_[Tjoi2013]拯救小矮人_贪心+DP Description 一群小矮人掉进了一个很深的陷阱里,由于太矮爬不上来,于是他们决定搭一个人梯.即:一个小矮人站在另一小矮人的 肩膀 ... 
- 【BZOJ3174】[TJOI2013]拯救小矮人(贪心,动态规划)
		[BZOJ3174][TJOI2013]拯救小矮人(贪心,动态规划) 题面 BZOJ 洛谷 题解 我们定义一个小矮人的\(A_i+B_i\)为它的逃跑能力. 我们发现,如果有两个小矮人\(x,y\), ... 
- 贪心+DP【洛谷P4823】 [TJOI2013]拯救小矮人
		P4823 [TJOI2013]拯救小矮人 题目描述 一群小矮人掉进了一个很深的陷阱里,由于太矮爬不上来,于是他们决定搭一个人梯.即:一个小矮人站在另一小矮人的 肩膀上,知道最顶端的小矮人伸直胳膊可以 ... 
随机推荐
- SQL SERVER2014的安装
			sqlserver2014安装 启动安装程序 下载sqlserver2014,双击startup.exe进行安装 系统配置检查器 使用系统配置检查器,看系统是否符合安装sqlserver2014的所有 ... 
- jQuery基础---Ajax基础
			内容提纲: 1.Ajax 概述 2.load()方法 3.$.get()和$.post() 4.$.getScript()和$.getJSON() 5.$.ajax()方法 6.表单序列化 发文不易, ... 
- 微信小程序初体验
			小程序最近太火,不过相比较刚发布时,已经有点热度散去的感觉,不过这不影响我们对小程序的热情,开发之前建议通读下官网文档,附链接:https://mp.weixin.qq.com/debug/wxado ... 
- Spring定时(任务)刷新-quartz
			Quartz是一个完全由java编写的开源作业调度框架.他可以与J2EE.J2SE集成,用与处理定时任务.定时刷新的需求.此处使用为与Spring项目集成. 在SpringMVC项目中使用quartz ... 
- [C#]LockBits使用笔记
			昨天想基于一张图片做个手机锁屏来着,原图如下:主要是嫌白底太丑了,一开始是想画图工具直接油漆桶伺候,然而一浇上去就发现问题了,变成了这样:看来得手工处理一下把底色统一了,原图分辨率挺高的,SetPix ... 
- 【SSH网上商城项目实战12】添加和更新商品功能的实现
			转自: https://blog.csdn.net/eson_15/article/details/51366370 添加商品部分原理和添加商品类别是一样的,不过要比商品类别复杂,因为商品的属性有很多 ... 
- JDBC入门(4)--- 批处理
			1.Statement批处理 当你有10条SQL语句要执行时,一次向服务器发送一条SQL语句,这样做的效率上极差,处理的方案是使用批处理,即一次向服务发送多条SQL语句,然后由服务器一次性处理. 批处 ... 
- 《JavaWeb从入门到改行》很好的复习资料: SQL语句到底怎么写 ?
			本文用到的数据库如下: CREATE DATABASE exam; /创建部门表/ CREATE TABLE dept( deptno INT PRIMARY KEY, dname ), loc ) ... 
- For循环中由于ajax异步导致的问题解决(增加alert数据正常,去掉alert之后数据错误)
			由于ajax异步请求的机制,for循环运行不会等内部ajax请求结束,而直接循环到最后.解决方法:将for循环里面的请求单独封装一个方法. 个人遇到的问题具体如下 下面这段代码,如果第5行studat ... 
- springcloud 实战  网关zuul使用中遇到的相关问题
			springcloud 实战 网关zuul使用中遇到的相关问题 1.网关zuul使用时,跨域问题在网关中配置pre过滤器: response.setHeader("Access-Contr ... 
