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 ...
随机推荐
- C++胜者树
#include <iostream> #define MAX_VALUE 0x7fffffff using namespace std; //在这里我先反思一下.不知道怎么搞的,这个算法 ...
- Dynamics CRM 2015/2016 Web API:Unbound Function 和 Bound Function
今天我们来看看Dynamics CRM Web API Function 吧, 这是一个新概念,刚接触的时候我也是比較的迷糊.这种命名确实是和之前的那套基于SOAP协议的API全然联系不上.好了,不说 ...
- WebApi自定义返回类型和命名空间实现
1.自定义ContentNegotiator /// <summary> /// 返回json的ContentNegotiator /// </summary> public ...
- Web网站架构演变—高并发、大数据
转 Web网站架构演变—高并发.大数据 2018年07月25日 17:27:22 gis_morningsun 阅读数:599 前言 我们以javaweb为例,来搭建一个简单的电商系统,看看这个系 ...
- ARCGIS动态画点
小马哥淡定 原文 ARCGIS动态画点 private void DrawPointOnMap(double x, double y,bool clear) { IMapControl2 pMapCt ...
- [CSS3] Create a fixed-fluid-fixed layout using CSS calc()
CSS calc() allows you to mix and match units to get real-time calculations. It's useful when you nee ...
- ANDROID内存优化(大汇总——全)
写在最前: 本文的思路主要借鉴了2014年AnDevCon开发者大会的一个演讲PPT,加上把网上搜集的各种内存零散知识点进行汇总.挑选.简化后整理而成. 所以我将本文定义为一个工具类的文章,如果你在A ...
- tomcat总体架构
Tomcat 总体结构图 从上图中可以看出Tomcat的心脏是两个组件:Connector 和 Container,关于这两个组件将在后面详细介绍.Connector 组件是可以被替换,这样可以提供给 ...
- [TypeStyle] Style CSS pseudo-classes using TypeStyle with $nest
TypeStyle is a very thin layer on top of CSS. In this lesson we show how to change styles based on p ...
- [Swift] Add Scroll View
import UIKit class AboutViewController : UIViewController @IBOutlet weak var scrollView: UIScrollVie ...