[Bzoj5254][Fjwc2018]红绿灯(线段树)
5254: [Fjwc2018]红绿灯
Time Limit: 10 Sec Memory Limit: 256 MB
Submit: 31 Solved: 24
[Submit][Status][Discuss]
Description
Input
Output
Sample Input
Sample Output
HINT
Source
AC代码:
# include <iostream>
# include <cstdio>
# include <algorithm>
using namespace std;
typedef long long LL;
const int N = 5e4 + ;
int block[N],tot,n,m,Q;LL G,C,P,d[N],b[N],s[N],f[N],w;
int mi[N << ];
void push(int x){mi[x] = min(mi[x << ],mi[x << | ]);}
void updata(int L,int l,int r,int rt,int v)
{
if(l == r){mi[rt] = v;return;}
int mid = l + r >> ;
if(L <= mid)updata(L,l,mid,rt << ,v);
else updata(L,mid + ,r,rt << | ,v);
push(rt);
}
int Query(int L,int R,int l,int r,int rt)
{
if(L > R)return n + ;
if(L <= l && r <= R)return mi[rt];
int mid = l + r >> ;
if(L > mid)return Query(L,R,mid + ,r,rt << | );
if(R <= mid)return Query(L,R,l,mid,rt << );
return min(Query(L,R,l,mid,rt << ),Query(L,R,mid + ,r,rt << | ));
}
int query(LL w)
{
w = (w % P + P) % P;
LL L,R;int lc,rc,k;
L = (G + w) % P,R = (P - + w) % P;
lc = lower_bound(b + ,b + m + ,L) - b;
rc = upper_bound(b + ,b + m + ,R) - b - ;
if(L <= R)k = Query(lc,rc,,m,);
else k = min(Query(lc,m,,m,),Query(,rc,,m,));
return k;
}
void add(int x,int y,LL bac)
{
f[x] = f[y] + s[y] - s[x];
if(y != n + )f[x] = f[x] + P - (s[y] - s[x] + bac) % P;
}
int main()
{
scanf("%d %lld %lld",&n,&G,&C);P = G + C;
for(int i = ;i <= n + ;i++)scanf("%lld",&d[i]);
for(int i = ;i <= n + ;i++)s[i] = s[i - ] + d[i],b[i] = s[i] % P;
b[n + ] = ;b[n + ] = P;
sort(b + ,b + n + );
m = unique(b + ,b + n + ) - b - ;
for(int i = ;i <= (m << );i++)mi[i] = n + ;
int k;
for(int i = n;i >= ;i--)
{
k = query(s[i] % P);
add(i,k,);
updata(lower_bound(b + ,b + m + ,s[i] % P) - b,,m,,i);
}
scanf("%d",&Q);
while(Q--)
{
scanf("%lld",&w);
k = query(-w);
add(,k,w);
printf("%lld\n",f[] + w);
}
}
[Bzoj5254][Fjwc2018]红绿灯(线段树)的更多相关文章
- BZOJ 5254 [Fjwc2018]红绿灯 (线段树)
题目大意:一个wly从家走到学校要经过n个红绿灯,绿灯持续时间是$g$,红灯是$r$,所有红绿灯同时变红变绿,交通规则和现实中一样,不能抢红灯,两个红绿灯之间道路的长度是$di$,一共$Q$个询问,求 ...
- BZOJ5254 FJWC2018红绿灯(线段树)
注意到一旦在某个路口被红灯逼停,剩下要走的时间是固定的.容易想到预处理出在每个路口被逼停后到达终点的最短时间,这样对于每个询问求出其最早在哪个路口停下就可以了.对于预处理,从下一个要停的路口倒推即可. ...
- BZOJ5254 : [Fjwc2018]红绿灯
显然所有询问都要经过至少$\sum d$,只需要考虑除了$\sum d$之外的等待红灯的时间. 将所有询问的时间模$g+r$,并按时间用set维护. 那么对于每个红灯,在set中可以找出$1$到$2$ ...
- bzoj3932--可持久化线段树
题目大意: 最近实验室正在为其管理的超级计算机编制一套任务管理系统,而你被安排完成其中的查询部分.超级计算机中的 任务用三元组(Si,Ei,Pi)描述,(Si,Ei,Pi)表示任务从第Si秒开始,在第 ...
- codevs 1082 线段树练习 3(区间维护)
codevs 1082 线段树练习 3 时间限制: 3 s 空间限制: 128000 KB 题目等级 : 大师 Master 题目描述 Description 给你N个数,有两种操作: 1:给区 ...
- codevs 1576 最长上升子序列的线段树优化
题目:codevs 1576 最长严格上升子序列 链接:http://codevs.cn/problem/1576/ 优化的地方是 1到i-1 中最大的 f[j]值,并且A[j]<A[i] .根 ...
- codevs 1080 线段树点修改
先来介绍一下线段树. 线段树是一个把线段,或者说一个区间储存在二叉树中.如图所示的就是一棵线段树,它维护一个区间的和. 蓝色数字的是线段树的节点在数组中的位置,它表示的区间已经在图上标出,它的值就是这 ...
- codevs 1082 线段树区间求和
codevs 1082 线段树练习3 链接:http://codevs.cn/problem/1082/ sumv是维护求和的线段树,addv是标记这歌节点所在区间还需要加上的值. 我的线段树写法在运 ...
- PYOJ 44. 【HNSDFZ2016 #6】可持久化线段树
#44. [HNSDFZ2016 #6]可持久化线段树 统计 描述 提交 自定义测试 题目描述 现有一序列 AA.您需要写一棵可持久化线段树,以实现如下操作: A v p x:对于版本v的序列,给 A ...
随机推荐
- Eclipse调试:项目在Debug模式下,无法启动的问题
问题:Eclipse中调试Java项目时,使用正常模式:Run 项目名,可以正常启动.当想打断点调试时,点击Debug按钮后,项目显示 Source not found,或者弹出窗口显示服务器在45秒 ...
- document节点的一些个性属性
<ol> <li>document.head:返回文档的< head>节点:</li> <li>document.body:返回文档的< ...
- 697. Degree of an Array@python
Given a non-empty array of non-negative integers nums, the degree of this array is defined as the ma ...
- 【meet in middle】poj1840Eqs
震惊!map的常数居然如此之大 Description Consider equations having the following form: a1x13+ a2x23+ a3x33+ a4x43 ...
- 【数论】贝壳找房计数比赛&&祭facinv
震惊!阶乘逆元处理背后竟有如此玄机…… 题目描述 贝壳找房举办了一场计数比赛,比赛题目如下. 给一个字符串 s 和字符串 t,求出 s 的所有去重全排列中 t 出现的次数.比如aab的去重全排列为aa ...
- Re:从零开始的Linux之路(杂谈)
决定认真从零开始写一个Linux的学习过程,像我这么偷懒的人能写文字记录已经很不容易了,希望不要半途而废吧(拖走) 用多了Linux其实发现,要是哪天Linux和Windows能结合下就好了,简单粗暴 ...
- 一段式fsm
//1-paragraph method to decribe FSM //Describe state transition, state output, state input condition ...
- perl学习之:read
perl read()函数例子,read()函数实例代码 - 读取,或试图读取,长度LENGTH 与文件句柄FILEHANDLE 相关联的文件到缓冲区BUFFER中的字节数. 语法 read FILE ...
- laravel如何利用数据库的形式发送通知
具体实现需要分几步: 1.修改驱动为database; 2.创建database的queue表 3.创建任务sendMessage 4.创建发送逻辑dispatch 5.启动队列 接下来我们进行实操: ...
- 【Oracle】使用dblink+minus方式迁移数据
一.需求说明 1.数据库a104的表syssde.a4_syssde_department中有1000条数据: 2.数据库a230的表syssde.a4_syssde_department中有800条 ...