模拟赛 yjqa
考场上怕是石乐志。
状态设计还是很自然的,求什么设什么。
f[i]表示前i个人安排好,电梯最早回到0层的时间
转移的话,枚举上一次最后一个带走的是谁
f[i]=min(max(f[j],t[i])+2*max(ak,j<k<=i))
线段树优化
后面的区间最大值,可以用单调栈记录,弹栈的时候,在线段树上区间赋值
t,f都是单调不降的,所以可以边找答案边二分,一半用t[i]和ak更新。一半用f[j]和ak更新。
记录区间最小ak,最小f[j]+aj,最小f[j],最大f[j](便于二分)
#include<bits/stdc++.h>
#define reg register int
#define il inline
#define mid ((l+r)>>1)
#define numb (ch^'0')
#define ls (x<<1)
#define rs (x<<1|1)
using namespace std;
typedef long long ll;
il void rd(int &x){
char ch;x=;bool fl=false;
while(!isdigit(ch=getchar()))(ch=='-')&&(fl=true);
for(x=numb;isdigit(ch=getchar());x=x*+numb);
(fl==true)&&(x=-x);
}
namespace Miracle{
const int N=+;
int n;
struct node{
ll mi,fmi,vmi,fmx;
ll ch;
node(){
ch=-;
}
}t[*N];
int tim[N],a[N];
int b[N];
int sta[*N],top;
ll f[N];
void pushup(int x){
t[x].mi=min(t[x<<].mi,t[x<<|].mi);
t[x].fmi=min(t[x<<].fmi,t[x<<|].fmi);
t[x].vmi=min(t[x<<].vmi,t[x<<|].vmi);
t[x].fmx=max(t[ls].fmx,t[rs].fmx);
}
void pushdown(int x){
if(t[x].ch==-) return;
t[ls].ch=t[x].ch;
t[ls].vmi=t[x].ch;
t[ls].mi=t[ls].fmi+*t[ls].vmi; t[rs].ch=t[x].ch;
t[rs].vmi=t[x].ch;
t[rs].mi=t[rs].fmi+*t[rs].vmi;
t[x].ch=-;
}
void upda(int x,int l,int r,int to,ll ak,ll c){
if(l==r){
t[x].fmi=c;
t[x].fmx=c;
t[x].vmi=ak;
t[x].mi=t[x].fmi+*t[x].vmi;
return;
}
pushdown(x);
if(to<=mid) upda(x<<,l,mid,to,ak,c);
else upda(x<<|,mid+,r,to,ak,c);
pushup(x);
}
void chan(int x,int l,int r,int L,int R,ll c){
if(L<=l&&r<=R){
t[x].ch=c;
t[x].vmi=t[x].ch;
t[x].mi=t[x].fmi+*t[x].vmi;
return;
}
pushdown(x);
if(L<=mid) chan(x<<,l,mid,L,R,c);
if(mid<R) chan(x<<|,mid+,r,L,R,c);
pushup(x);
}
ll query(int x,int l,int r,int L,int R,ll c){
if(L<=l&&r<=R){
pushdown(x);
if(t[x].fmi<t[x].fmx&&t[x].fmi<=c&&c<=t[x].fmx){
return min(query(x<<,l,mid,L,R,c),query(x<<|,mid+,r,L,R,c));
}
if(t[x].fmx<=c){
return c+*t[x].vmi;
}
if(t[x].fmi>=c){
return t[x].mi;
}
}
pushdown(x);
ll ret=0x3f3f3f3f3f3f3f3f;
if(L<=mid) ret=min(ret,query(x<<,l,mid,L,R,c));
if(mid<R) ret=min(ret,query(x<<|,mid+,r,L,R,c));
return ret;
}
int main(){
rd(n);
for(reg i=;i<=n+;++i){
rd(tim[i]),rd(a[i]);
}
for(reg i=;i<=n;++i){
b[i]=a[i+];
}
sta[++top]=;
upda(,,n,,b[],);
for(reg i=;i<=n+;++i){
//cout<<" ii "<<i<<endl; f[i]=query(,,n,,i-,tim[i]);
//cout<<" f[i] "<<f[i]<<endl;
if(i!=n+)
{
upda(,,n,i,b[i],f[i]);
while(top&&b[sta[top]]<b[i]){
//cout<<sta[top]<<endl;
chan(,,n,sta[top-]+,sta[top],b[i]);
--top;
}
sta[++top]=i;
}
}
printf("%lld",f[n+]);
return ;
} }
signed main(){
Miracle::main();
return ;
} /*
Author: *Miracle*
Date: 2018/12/24 21:59:28
*/
模拟赛 yjqa的更多相关文章
- NOIP模拟赛20161022
NOIP模拟赛2016-10-22 题目名 东风谷早苗 西行寺幽幽子 琪露诺 上白泽慧音 源文件 robot.cpp/c/pas spring.cpp/c/pas iceroad.cpp/c/pas ...
- NOI模拟赛 Day1
[考完试不想说话系列] 他们都会做呢QAQ 我毛线也不会呢QAQ 悲伤ING 考试问题: 1.感觉不是很清醒,有点困╯﹏╰ 2.为啥总不按照计划来!!! 3.脑洞在哪里 4.把模拟赛当作真正的比赛,紧 ...
- NOIP第7场模拟赛题解
NOIP模拟赛第7场题解: 题解见:http://www.cqoi.net:2012/JudgeOnline/problemset.php?page=13 题号为2221-2224. 1.car 边界 ...
- contesthunter暑假NOIP模拟赛第一场题解
contesthunter暑假NOIP模拟赛#1题解: 第一题:杯具大派送 水题.枚举A,B的公约数即可. #include <algorithm> #include <cmath& ...
- NOIP模拟赛 by hzwer
2015年10月04日NOIP模拟赛 by hzwer (这是小奇=> 小奇挖矿2(mining) [题目背景] 小奇飞船的钻头开启了无限耐久+精准采集模式!这次它要将原矿运到泛光之源的矿 ...
- 小奇模拟赛9.13 by hzwer
2015年9月13日NOIP模拟赛 by hzwer (这是小奇=> 小奇挖矿(explo) [题目背景] 小奇要开采一些矿物,它驾驶着一台带有钻头(初始能力值w)的飞船,按既定路线依次飞 ...
- PKUSC 模拟赛 day1 下午总结
下午到了机房之后又困又饿,还要被强行摁着看英文题,简直差评 第一题是NOIP模拟赛的原题,随便模拟就好啦 本人模拟功力太渣不小心打错了个变量,居然调了40多分钟QAQ #include<cstd ...
- [GRYZ]寒假模拟赛
写在前面 这是首次广饶一中的OIERS自编自导,自出自做(zuo)的模拟赛. 鉴于水平气压比较低,机(wei)智(suo)的WMY/XYD/HYXZC就上网FQ下海找了不少水(fei)题,经过他们优( ...
- BZOJ2741: 【FOTILE模拟赛】L
2741: [FOTILE模拟赛]L Time Limit: 15 Sec Memory Limit: 162 MBSubmit: 1170 Solved: 303[Submit][Status] ...
随机推荐
- YII2.0 用GII创建视图文件后访问404
使用GII的CRUD Generator创建searchModelClass 和控制器类文件,视图文件后,访问控制器地址后出现404的情况. 创建过程如图所示 后来发现是控制器类 Controller ...
- EpiiAdmin 开源的php交互性管理后台框架, 让复杂的交互变得更简单!Phper快速搭建交互性平台的开发框架,基于Thinkphp5.1+Adminlte3.0+Require.js。
EpiiAdmin EpiiAdmin php开源交互性管理后台框架,基于Thinkphp5.1+Adminlte3.0+Require.js, 让复杂的交互变得更简单!Phper快速搭建交互性平台的 ...
- Python学习:If 语句与 While 语句
If 语句 用以检查条件:如果条件为真(True),将运行这一块的语句(称作 if-block 或 if 块) 则将运行另一块语句(称作 else-block 或 else 块),其中 else ...
- BZOJ3265: 志愿者招募加强版(线性规划)
Time Limit: 20 Sec Memory Limit: 512 MBSubmit: 809 Solved: 417[Submit][Status][Discuss] Descriptio ...
- SpringMVC接收前端传值有哪些方式?
有很多种,比如: 1.通过@RequestParam注解接收请求参数: 2.通过Bean封装,接收多个请求参数 3.通过@ModelAttribute绑定接收前端表单数据 4.通过@PathVaria ...
- 也谈js传值和传址
通常的认识就是基本的数值元素是传值,对象等复杂结构传址,无需争论,一试便知. 首先是数值 var a = 1 var b = a a = 2 console.log(a) console.log(b) ...
- 初步学习pg_control文件之五
接前文 初步学习pg_control文件之四,继续看何时出现 DB_IN_CRASH_RECOVERY: 看下面代码就比较清楚了:如果对 InArchiveRecovery 判断值为假,而且 读取出 ...
- php-configure错误解决
configure: error: libjpeg.(a|so) not foundconfigure: error: libjpeg.(a|so) not foundln -sf libjpeg.s ...
- 发布npm包 登录报错 E409 Conflict
1.到官网注册个账号,并且验证完邮箱:https://www.npmjs.com/ 2.打开cmd命令行 登录:$npm login 根据提示 一步步完成登录. 3.新建一个项目文件夹: npmtes ...
- Python 中的容器 collections
写在之前 我们都知道 Python 中内置了许多标准的数据结构,比如列表,元组,字典等.与此同时标准库还提供了一些额外的数据结构,我们可以基于它们创建所需的新数据结构. Python 附带了一个「容器 ...