Codeforces 777E - Hanoi Factory(贪心+栈)
题目链接:http://codeforces.com/problemset/problem/777/E
题意:有n个环给你内环半径、外环半径和高度,叠这些环还要满足以下要求:
①:下面的环的外径要>=上面的环
②:环不能掉下去,所以下面的环的内径要<上面的环的外径
③:叠出最大高度
思路:贪心思想,先把这些环按外径从大到小,内径从大到小排好序,内径从大到小是为了尽可能让后面的环能放上去。接下来就可以用栈模拟了,放1~n个环的时每次都要判断,如果当前最顶上的环的内径大于我要放的环的内径也就是放不上去,那就把顶上的环出栈,一直循环直到能放上去为止,再把当前环入栈。然后每次都比较一下高度和,得出最大高度。为什么可以用栈写?因为我们已经知道前面的环叠不上后面的环肯定也叠不上,因为后面的环外径肯定<=前面的环,那把栈当成已经建好的塔,如果环放不上去,为了后面可以继续放,那可以拆了一部分重建。
这是开始没用栈的无脑代码从头到尾遍历了一遍,直接超时,心塞- -、、:
#include<iostream>
#include<algorithm>
#include<string>
using namespace std;
const int N=1e5+;
typedef long long ll;
struct node{
int in;
int out;
int h;
}a[N];
ll dp[N]; bool cmp(node a,node b){
return a.out==b.out?a.in>b.in:a.out>b.out;
} int main(){
ll n,ans=;
cin>>n;
for(int i=;i<=n;i++){
cin>>a[i].in>>a[i].out>>a[i].h;
if(a[i].h>ans)
ans=a[i].h;
}
sort(a+,a++n,cmp);
// cout<<endl;
// for(int i=1;i<=n;i++){
// cout<<a[i].in<<" "<<a[i].out<<" "<<a[i].h<<endl;
// }
for(int i=;i<=n;i++){
dp[i]=a[i].h;
for(int j=;j<i;j++){
if(a[i].out>=a[j].in)
dp[i]=max(dp[i],dp[j]+a[i].h);
}
ans=max(ans,dp[i]);
}
cout<<ans<<endl;
}
这是用栈写的:
#include<iostream>
#include<algorithm>
#include<stack>
using namespace std;
const int N=1e5+;
typedef long long ll;
struct node{
int in;
int out;
int h;
}a[N];
ll dp[N]; bool cmp(node a,node b){
return a.out==b.out?a.in>b.in:a.out>b.out;
}
int main(){
ll n;
stack<node>s;
cin>>n;
for(int i=;i<=n;i++){
cin>>a[i].in>>a[i].out>>a[i].h;
}
sort(a+,a++n,cmp);
// cout<<endl;
// for(int i=1;i<=n;i++){
// cout<<a[i].in<<" "<<a[i].out<<" "<<a[i].h<<endl;
// }
ll sum=,ans=;
for(int i=;i<=n;i++){
while(!s.empty()&&a[i].out<=s.top().in){//判断是否能叠上去,不能的话就把最顶上的环拿下来
sum-=s.top().h;
s.pop();
}
sum+=a[i].h;
s.push(a[i]);
ans=max(ans,sum); //比较最大高度
}
cout<<ans<<endl;
}
Codeforces 777E - Hanoi Factory(贪心+栈)的更多相关文章
- Codeforces 777E Hanoi Factory(线段树维护DP)
题目链接 Hanoi Factory 很容易想到这是一个DAG模型,那么状态转移方程就出来了. 但是排序的时候有个小细节:b相同时看a的值. 因为按照惯例,堆塔的时候肯定是内半径大的在下面. 因为N有 ...
- codeforces-777E Hanoi Factory (栈+贪心)
题目传送门 题目大意: 现在一共有N个零件,如果存在:bi>=bj&&bj>ai的两个零件i,j,那么此时我们就可以将零件j放在零件i上.我们现在要组成一个大零件,使得高度 ...
- Codeforces 777E:Hanoi Factory(贪心)
Of course you have heard the famous task about Hanoi Towers, but did you know that there is a specia ...
- Codeforces777E. Hanoi Factory 2017-05-04 18:10 42人阅读 评论(0) 收藏
E. Hanoi Factory time limit per test 1 second memory limit per test 256 megabytes input standard inp ...
- codeforces 704B - Ant Man 贪心
codeforces 704B - Ant Man 贪心 题意:n个点,每个点有5个值,每次从一个点跳到另一个点,向左跳:abs(b.x-a.x)+a.ll+b.rr 向右跳:abs(b.x-a.x) ...
- CodeForces - 50A Domino piling (贪心+递归)
CodeForces - 50A Domino piling (贪心+递归) 题意分析 奇数*偶数=偶数,如果两个都为奇数,最小的奇数-1递归求解,知道两个数都为1,返回0. 代码 #include ...
- Codeforces 777E(离散化+dp+树状数组或线段树维护最大值)
E. Hanoi Factory time limit per test 1 second memory limit per test 256 megabytes input standard inp ...
- Codeforces 777E:Hanoi Factory(贪心+栈)
http://codeforces.com/problemset/problem/777/E 题意:给出n个环状圆柱,每个圆环有一个内半径a,外半径b,和高度h,只有外半径bj <= bi并且b ...
- CF #401 (Div. 2) E. Hanoi Factory (栈+贪心)
题意:给你一堆汉诺塔的盘子,设内半径为a,设外半径为b,高度为h,如果bj ≤ bi 同时bj > ai 我们就认为i盘子能落在在j盘子上,问你最高能落多高 思路:一看题意我们就能想到贪心,首先 ...
随机推荐
- bzoj 1823: [JSOI2010]满汉全席 && bzoj 2199 : [Usaco2011 Jan]奶牛议会 2-sat
noip之前学的内容了,看到题竟然忘了怎么建图了,复习一下. 2-sat 大概是对于每个元素,它有0和1两种选择,必须选一个但不能同时选.这之间又有一些二元关系,比如x&y=1等等... 先把 ...
- 阿里云 邮件发送(Python)
#coding:utf8 from smtplib import SMTP_SSL from email.header import Header from email.mime.text impor ...
- SQL复杂语句查询练习
--复杂查询练习 -- 1 .列出所有员工的年工资,按年薪从低到高排序. SELECT (SAL+NVL(COMM,0))*12 INCOME FROM EMP ORDER BY INCOME; -- ...
- for循环 底层工作原理
for 循环是对容器进行迭代的过程. 什么是迭代? 迭代就是从某个容器对象中逐个地读取元素,直到容器中没有更多元素为止. for 循环的步骤是什么? 先判断对象是否为可迭代对象,不是的话直接报错,抛出 ...
- Kubernetes init container
目录 简介 配置 init container与应用容器的区别 简介 在很多应用场景中,应用在启动之前都需要进行如下初始化操作: 等待其他关联组件正确运行(例如数据库或某个后台服务) 基于环境变量或配 ...
- P2684 搞清洁
P2684 搞清洁 给定一段区间及若干个线段, 求使区间被完全覆盖所需的最少线段数 错误日志: 菜 Solution 补一下贪心吧 这题最小线段覆盖 首先按照左端点排序 现在对于所有左区间到达目前已覆 ...
- SpringBoot(十一):Spring boot 中 mongodb 的使用
原文出处: 纯洁的微笑 mongodb是最早热门非关系数据库的之一,使用也比较普遍,一般会用做离线数据分析来使用,放到内网的居多.由于很多公司使用了云服务,服务器默认都开放了外网地址,导致前一阵子大批 ...
- JVM小结--类文件结构
字节码是构成Java平台无关性的基石.实现语言无关性的基础是虚拟机和字节码存储格式. Java语言中的各种变量.关键字和运算符的语义最终是由多条字节码命令组成,因此字节码命令所能提供的语义描述能力肯定 ...
- 基本UDP套接字编程
概述 使用TCP编写的应用程序和使用UDP编写的应用程序之间存在一些本质差异,其原因在于这两个传输层之间的差别:UDP是无连接不可靠的数据报协议,非常不同于TCP提供的面向连接的可靠字节流.然而相比T ...
- ASP.NET CORE API Swagger+IdentityServer4授权验证
简介 本来不想写这篇博文,但在网上找到的文章博客都没有完整配置信息,所以这里记录下. 不了解IdentityServer4的可以看看我之前写的入门博文 Swagger 官方演示地址 源码地址 配置Id ...