Codeforces 85B. Embassy Queue【段树、馋】
标题效果:
做法:
那么关键点就是怎么计算出这个时间。
涉及到这种操作的话,那当然想到了线段树。
我们用三个线段树,分别处理不同类型的窗体的信息。
#include <iostream>
#include <cstdio>
#include <climits>
#include <algorithm>
#define N 100010
#define L(x) (x)<<1
#define R(x) (x)<<1|1
using namespace std;
struct node
{
long long ll,rr,mi,pos;
node()
{
ll=rr=pos=0;
mi=INT_MAX;
}
node(long long l,long long r,long long m,long long p)
{
ll=l,rr=r,mi=m,pos=p;
}
}ty[4][N*4];
long long k[4][N],n[4],t[4],peo[N];
long long nn;
void bulid(long long id,long long l,long long r,long long na)
{
ty[na][id]=node(l,r,0,l);
if(l==r) return ;
long long mid=(l+r)/2;
bulid(L(id),l,mid,na);
bulid(R(id),mid+1,r,na);
}
void update(long long id,long long k,long long a,long long na)
{
if(k==ty[na][id].ll && ty[na][id].rr==k){ty[na][id].mi=a;return ;}
long long mid=(ty[na][id].ll+ty[na][id].rr)/2;
if(k>mid) update(R(id),k,a,na);
else update(L(id),k,a,na);
if(ty[na][L(id)].mi<=ty[na][R(id)].mi)
{
ty[na][id].mi=ty[na][L(id)].mi;
ty[na][id].pos=ty[na][L(id)].pos;
}
else
{
ty[na][id].mi=ty[na][R(id)].mi;
ty[na][id].pos=ty[na][R(id)].pos;
}
}
long long query(long long id,long long l,long long r,long long na,long long &index)
{
if(ty[na][id].ll==l&&ty[na][id].rr==r)
{
index=ty[na][id].pos;
return ty[na][id].mi;
}
long long mid=(ty[na][id].ll+ty[na][id].rr)/2;
if(mid>=r) return query(L(id),l,r,na,index);
else if(mid<l) return query(R(id),l,r,na,index);
else
{
long long tmp1,tmp2;
long long t1=query(L(id),l,mid,na,tmp1);
long long t2=query(R(id),mid+1,r,na,tmp2);
if(t1<=t2) {index=tmp1;return t1;}
else {index=tmp2;return t2;}
}
}
int main()
{
for(long long i=1;i<=3;i++)
scanf("%I64d",&n[i]);
for(long long i=1;i<=3;i++)
scanf("%I64d",&t[i]);
scanf("%d",&n[0]);
for(long long i=0;i<n[0];i++)
scanf("%I64d",peo+i),peo[i]--; for(long long i=1;i<=3;i++)
bulid(1,1,min(n[i],n[0]),i);
long long ans=0;
for(long long i=0;i<n[0];i++)
{
long long cur=peo[i];
for(long long j=1;j<=3;j++)
{
long long index;
long long c_mi=query(1,1,min(n[j],n[0]),j,index);
if(c_mi>=cur) cur=c_mi+t[j];
else cur+=t[j];
update(1,index,cur,j);
}
ans=max(ans,cur-peo[i]);
}
cout<<ans<<endl;
return 0;
}
版权声明:本文博主原创文章。博客,未经同意不得转载。
Codeforces 85B. Embassy Queue【段树、馋】的更多相关文章
- PKU A Simple Problem with Integers (段树更新间隔总和)
意甲冠军:一个典型的段树C,Q问题,有n的数量a[i] (1~n),C, a, b,c在[a,b]加c Q a b 求[a,b]的和. #include<cstdio> #include& ...
- 计蒜客 30996.Lpl and Energy-saving Lamps-线段树(区间满足条件最靠左的值) (ACM-ICPC 2018 南京赛区网络预赛 G)
G. Lpl and Energy-saving Lamps 42.07% 1000ms 65536K During tea-drinking, princess, amongst other t ...
- HDU 6356.Glad You Came-线段树(区间更新+剪枝) (2018 Multi-University Training Contest 5 1007)
6356.Glad You Came 题意就是给你一个随机生成函数,然后从随机函数里确定查询的左右区间以及要更新的val值.然后最后求一下异或和就可以了. 线段树,区间最大值和最小值维护一下,因为数据 ...
- HDU 5649.DZY Loves Sorting-线段树+二分-当前第k个位置的数
DZY Loves Sorting Time Limit: 12000/6000 MS (Java/Others) Memory Limit: 262144/262144 K (Java/Oth ...
- 计蒜客 28315.Excellent Engineers-线段树(单点更新、区间最值) (Benelux Algorithm Programming Contest 2014 Final ACM-ICPC Asia Training League 暑假第一阶段第二场 E)
先写这几道题,比赛的时候有事就只签了个到. 题目传送门 E. Excellent Engineers 传送门 这个题的意思就是如果一个人的r1,r2,r3中的某一个比已存在的人中的小,就把这个人添加到 ...
- 【UVA】11992 - Fast Matrix Operations(段树模板)
主体段树,要注意,因为有set和add操作,当慵懒的标志下推.递归优先set,后复发add,每次运行set行动add马克清0 WA了好几次是由于计算那一段的时候出问题了,可笑的是我对着模板找了一个多小 ...
- [Codeforces 1197E]Culture Code(线段树优化建图+DAG上最短路)
[Codeforces 1197E]Culture Code(线段树优化建图+DAG上最短路) 题面 有n个空心物品,每个物品有外部体积\(out_i\)和内部体积\(in_i\),如果\(in_i& ...
- BZOJ-3212 Pku3468 A Simple Problem with Integers 裸线段树区间维护查询
3212: Pku3468 A Simple Problem with Integers Time Limit: 1 Sec Memory Limit: 128 MB Submit: 1278 Sol ...
- ZOJ 1610 间隔染色段树
要长8000仪表板.间染色的范围,问:最后,能看到的颜色,而且颜色一共有段出现 覆盖段 数据对比水 水可太暴力 段树: #include "stdio.h" #include ...
随机推荐
- HDU 5372 线段树
给出两种操作: 第i个0:在x位置插入一个长度为i的线段,并输出该线段共覆盖了多少之前增加的线段 1:删除第i次插入的线段 官方题解:对于新插入的线段,查询有多少个线段左端点大于等于该线段的左端点. ...
- SVGALib
SVGALib是一套运行于Linux及FreeBSD下的开放源代码低阶绘图函式库,它允许程式设计人员变更视讯模式及全屏幕图像,许多热门的电脑游戏如Quake及Doom都源自此技术. 范例 编辑 #in ...
- 10.9 android输入系统_APP跟输入系统建立联系和Dispatcher线程_分发dispatch
12. 输入系统_APP跟输入系统建立联系_InputChannel和Connection核心: socketpair // 第9课第3节_输入系统_必备Linux编程知识_任意进程双向通信(scok ...
- 10.1、android输入系统_必备Linux编程知识_inotify和epoll
1. inotify和epoll 怎么监测键盘接入与拔出? (1)hotplug机制:内核发现键盘接入/拔出==>启动hotplug进程==>发消息给输入系统 (2)inotify机制:输 ...
- 【Codeforces Round #440 (Div. 2) B】Maximum of Maximums of Minimums
[链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] k=1的时候就是最小值, k=2的时候,暴力枚举分割点. k=3的时候,最大值肯定能被"独立出来",则直接输出最 ...
- CSS布局开篇
原文: 简书原文:https://www.jianshu.com/p/2c78b927f8c4 开篇 这是我写CSS布局的第一篇文章,之所以将布局从中摘出来单独放一部分是因为我觉得光是布局这块内容就有 ...
- js进阶ajax读取json数据(ajax读取json和读取普通文本,和获取服务器返回数据(链接)都是一样的,在url处放上json文件的地址即可)
js进阶ajax读取json数据(ajax读取json和读取普通文本,和获取服务器返回数据(链接)都是一样的,在url处放上json文件的地址即可) 一.总结 ajax读取json和读取普通文本,和获 ...
- angular管道相关知识
原文地址 https://www.jianshu.com/p/22e0f95bcf24 什么是管道 每个应用开始的时候差不多都是一些简单任务:获取数据.转换它们,然后把它们显示给用户. 获取数据可能简 ...
- ng-cli搭建angular项目框架
原文地址 https://www.jianshu.com/p/0a8f4b0f29b3 环境准备 以下步骤都不需要事先创建文件夹,只是环境的准备过程,只有到需要搭建项目的时候才需要创建文件夹用来存放项 ...
- iOS开发SDWebImage的基本使用
#import "ViewController.h" #import "UIImageView+WebCache.h" #import "SDWebI ...