【例题收藏】◇例题·IV◇ Wooden Sticks
◇例题·IV◇ Wooden Sticks
借鉴了一下 Candy? 大佬的思路 +传送门+ (=^-ω-^=)
来源:+POJ 1065+
◆ 题目大意
有n个木棍以及一台处理木棍的机器。第i个木棍用二元组 (li,wi) 表示,li 为它的长度,wi 为它的重量。
机器可以连续处理木棍{a[1],a[2]...a[m]}当且仅当对于每一个i(1≤i<m) la[i]<la[i+1] 且 wa[i]<wa[i+1] 。机器连续处理木棍的时间是1单位。你需要将这些木棍按一定顺序在机器中处理,求最少需要花费多少的时间。
例如:按顺序 ( 4 , 1 ) , ( 5 , 3 ) , ( 9 , 4 ) , ( 1 , 2 ) , ( 2 , 5 ) 处理,花费时间为2。
◆ 解析
这道题对STL的运用非常巧妙(我不知道为什么老师把这道题放在DP里……)
将问题简化一下,其实就是将木棍分成多个不上升序列,求最少序列数。我们不妨将这些序列设为 seq[1~m],那么判断一根木棍能否插入到某一个序列末尾,就是判断它的w和l是否都小于序列的末尾元素。
然后就是一个比较明显的贪心思想:若木棍x可以插入序列i或序列j的末尾,但是i的末尾要大于j的末尾,我们就把x插入i而不是j,这样能够让j插入更多的元素。
接下来就是实现了!
由于求不上升子序列和求不下降子序列是一个道理(?留给reader们思考一下),所以我们可以算最长不下降子序列。还有一个麻烦就是木棍是二元组,同时考虑两个值很麻烦,所以我们可以先sort一遍,按w为关键字(l为第二关键字),这样保证插入时w的这一维是不下降的。然后我们就只需要考虑 l 这一维。
由于我们只需要用到每一个不下降序列的末尾元素,我们可以定seq[i]表示第i个不下降序列的末尾元素。一开始所有序列seq都是空,而我们要使第一根木棍一定能够插入到序列中,我们就可以把序列末尾全部清空为负无穷。
然后就是STL的lower_bound()了——找到小于等于特定值的最大元素第一次出现的位置。插入 i 时,我们在序列末尾seq中查找小于等于 木棍i的l 的最大的序列末尾,然后插入该序列(贪心)。
◆ 源代码
/*Lucky_Glass*/
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
const int MAXN=,INF=int(1e9);
struct WOOD{
int w,l;
}wood[MAXN+];
int n;
int seq[MAXN+]; //seq[i]表示第i组连续处理的木棍最后处理的木棍的l
bool cmp(int a,int b){return a>b;}
bool cmp_(WOOD A,WOOD B) //按w为第一关键字排序,l为第二关键字
{
if(A.w>B.w) return ; //较小的放前面
if(A.w<B.w) return ;
return A.l<B.l;
}
int Solve()
{
int ans=;
sort(wood+,wood++n,cmp_); //先排序,排序后wood按w形成升序
fill(seq,seq+MAXN+,-INF); //初始化,这样第一根木棍无论如何都可以插入到seq中
for(int i=;i<=n;i++)
{
int pos=lower_bound(seq+,seq++n,wood[i].l,cmp)-seq; //找到最大的可以继续连续处理木棍的组数
seq[pos]=wood[i].l; //更新最后处理的l
ans=max(ans,pos); //处理答案
}
return ans;
}
int main()
{
int T;scanf("%d",&T);
while(T--)
{
scanf("%d",&n);
for(int i=;i<=n;i++)
scanf("%d%d",&wood[i].w,&wood[i].l);
printf("%d\n",Solve());
}
return ;
}
The End
Thanks for reading!
- Lucky_Glass
【例题收藏】◇例题·IV◇ Wooden Sticks的更多相关文章
- Hdu1051 Wooden Sticks 2017-03-11 23:30 62人阅读 评论(0) 收藏
Wooden Sticks Problem Description There is a pile of n wooden sticks. The length and weight of each ...
- HDOJ 1051. Wooden Sticks 贪心 结构体排序
Wooden Sticks Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) To ...
- POJ 1065 Wooden Sticks
Wooden Sticks Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 16262 Accepted: 6748 Descri ...
- HDU ACM 1051/ POJ 1065 Wooden Sticks
Wooden Sticks Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Tot ...
- 1051 Wooden Sticks
Wooden Sticks Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Tot ...
- Wooden Sticks
Wooden Sticks Time Limit : 2000/1000ms (Java/Other) Memory Limit : 65536/32768K (Java/Other) Total ...
- C - Wooden Sticks
C - Wooden Sticks Time Limit:1000MS Memory Limit:32768KB 64bit IO Format:%I64d & %I64u S ...
- HDU 1051 Wooden Sticks (贪心)
Wooden Sticks Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) To ...
- uvalive 2322 Wooden Sticks(贪心)
题目连接:2322 Wooden Sticks 题目大意:给出要求切的n个小木棍 , 每个小木棍有长度和重量,因为当要切的长度和重量分别大于前面一个的长度和重量的时候可以不用调整大木棍直接切割, 否则 ...
随机推荐
- AndroidStudio项目提交到github最详细步骤
在使用studio开发的项目过程中有时候我们想将项目发布到github上,以前都是用一种比较麻烦的方式(cmd)进行提交,最近发现studio其实是自带这种功能的,终于可以摆脱命令行了. 因为自己也没 ...
- Spring Boot实战(2) Spring常用配置
1. Bean的Scope scope描述Spring容器如何新建Bean的实例.通过注解@Scope实现,取值有: a. Singleton:一个Spring容器中只有一个Bean的实例.此为Spr ...
- GitKraken使用教程-基础部分(9)
10. 合并分支并解决冲突(conflict) 1) 合并分支 在代码管理过程中,切换分支或者同步服务器代码时,常常会出现代码冲突的情况,这种情况出现的原因一般是由于两个分支对同一个文件进行修改, ...
- REST API 自动化测试 利器Rest Assured(API接口自动化测试框架体系)
现在,越来越多的 Web 应用转向了 RESTful 的架构,很多产品和应用暴露给用户的往往就是一组 REST API,这样有一个好处,用户可以根据需要,调用不同的 API,整合出自己的应用出来.从这 ...
- springboot2.x如何添加事务
什么时候需要添加事务呢?一般情况下,如果该方法有两条SQL语句或者以上都需要添加(个人感觉:)). 首先需要在我们的启动类加上 @EnableTransactionManagement //开启事务管 ...
- 卸载jrebel
Setting-Plugins-搜索Jrebel-右击选择Uninstall-apply 确认重启idea即可
- Python并发编程之进程池与线程池
一.进程池与线程池 python标准模块concurrent.futures(并发未来) 1.concurrent.futures模块是用来创建并行的任务,提供了更高级别的接口,为了异步执行调用 2. ...
- [原创]Centos7 安装配置ASP.NET Core+Nginx+Supervisor
序言 此教程安装的都是最新版本的. 一键安装 有了这个神器,下面的教程就不用做了!只需运行几行代码,直接打开浏览器就可以访问! cd /home/ wget https://files.cnblogs ...
- PowerShell 脚本域策略管理
大中型企业中,会设置许多组策略进行日常运维管理 ,毕然里面也存在许多废弃的策略,需要我们定期清理我们的组策略信息.通常我们导出HTML报告方式来帮助我们分析组策略信息: #1 首先需要加载GroupP ...
- C#正则表达式获取网址的域名(IP)
代码如下: string p = @"(http|https)://(?<domain>[^(:|/]*)"; Regex reg = new Regex(p, Reg ...