BZOJ 1251: 序列终结者 [splay]
1251: 序列终结者
Time Limit: 20 Sec Memory Limit: 162 MB
Submit: 3778 Solved: 1583
[Submit][Status][Discuss]
Description
网上有许多题,就是给定一个序列,要你支持几种操作:A、B、C、D。一看另一道题,又是一个序列 要支持几种操作:D、C、B、A。尤其是我们这里的某人,出模拟试题,居然还出了一道这样的,真是没技术含量……这样 我也出一道题,我出这一道的目的是为了让大家以后做这种题目有一个“库”可以依靠,没有什么其他的意思。这道题目 就叫序列终结者吧。 【问题描述】 给定一个长度为N的序列,每个序列的元素是一个整数(废话)。要支持以下三种操作: 1. 将[L,R]这个区间内的所有数加上V。 2. 将[L,R]这个区间翻转,比如1 2 3 4变成4 3 2 1。 3. 求[L,R]这个区间中的最大值。 最开始所有元素都是0。
Input
第一行两个整数N,M。M为操作个数。 以下M行,每行最多四个整数,依次为K,L,R,V。K表示是第几种操作,如果不是第1种操作则K后面只有两个数。
Output
对于每个第3种操作,给出正确的回答。
Sample Input
1 1 3 2
1 2 4 -1
2 1 3
3 2 4
Sample Output
【数据范围】
N<=50000,M<=100000。
- #include <iostream>
- #include <cstdio>
- #include <cstring>
- #include <algorithm>
- #include <cmath>
- using namespace std;
- typedef long long ll;
- #define lc t[x].ch[0]
- #define rc t[x].ch[1]
- #define pa t[x].fa
- const int N=1e5+,INF=1e9;
- inline int read(){
- char c=getchar();int x=,f=;
- while(c<''||c>''){if(c=='-')f=-; c=getchar();}
- while(c>=''&&c<=''){x=x*+c-''; c=getchar();}
- return x*f;
- }
- int n,Q,op,l,r,v;
- struct node{
- int fa,ch[],size,rev,mx,v,tag;
- }t[N];
- int root;
- inline int wh(int x){return t[pa].ch[]==x;}
- inline void update(int x){
- t[x].size=t[lc].size+t[rc].size+;
- t[x].mx=max(t[x].v,max(t[lc].mx,t[rc].mx));
- }
- inline void pushDown(int x){
- if(t[x].rev){
- swap(lc,rc);
- if(lc) t[lc].rev^=;
- if(rc) t[rc].rev^=;
- t[x].rev=;
- }
- if(t[x].tag){
- int v=t[x].tag;
- if(lc) t[lc].tag+=v,t[lc].v+=v,t[lc].mx+=v;
- if(rc) t[rc].tag+=v,t[rc].v+=v,t[rc].mx+=v;
- t[x].tag=;
- }
- }
- int build(int l,int r,int f){//printf("build %d %d %d\n",l,r,f);
- if(l>r) return ;
- int x=(l+r)>>;
- lc=build(l,x-,x);rc=build(x+,r,x);
- t[x].fa=f;
- t[x].rev=t[x].tag=;t[x].v=t[x].mx=;
- update(x);
- return x;
- }
- inline void rotate(int x){
- int f=t[x].fa,g=t[f].fa,c=wh(x);
- if(g) t[g].ch[wh(f)]=x;t[x].fa=g;
- t[f].ch[c]=t[x].ch[c^];t[t[f].ch[c]].fa=f;
- t[x].ch[c^]=f;t[f].fa=x;
- update(f);update(x);
- }
- void splay(int x,int tar){
- for(;t[x].fa!=tar;rotate(x))
- if(t[pa].fa!=tar) rotate(wh(x)==wh(pa)?pa:x);
- if(tar==) root=x;
- }
- inline int kth(int k){
- int ls=,x=root;
- while(x){
- pushDown(x);
- int _=ls+t[lc].size;
- if(_<k&&k<=_+) return x;
- if(k<=_) x=lc;
- else ls=_+,x=rc;
- }
- return -;
- }
- void add(int l,int r,int v){//printf("add %d %d %d\n",l,r,v);
- int p=kth(l);splay(p,);
- int x=kth(r+);splay(x,root);
- t[lc].tag+=v;t[lc].v+=v;t[lc].mx+=v;
- }
- void rev(int l,int r){
- int p=kth(l);splay(p,);
- int x=kth(r+);splay(x,root);
- t[lc].rev^=;
- }
- void getmax(int l,int r){
- int p=kth(l);splay(p,);
- int x=kth(r+);splay(x,root);
- printf("%d\n",t[lc].mx);
- }
- void print(int x){
- if(x==) return;
- pushDown(x);
- if(lc) print(lc);
- if(x!=&&x!=n+) printf("%d ",t[x].v);
- if(rc) print(rc);
- }
- int main(){
- //freopen("in.txt","r",stdin);
- n=read();Q=read();
- t[].mx=-INF;
- root=build(,n+,);
- //for(int i=1;i<=n+2;i++) printf("hi %d %d %d\n",i,t[i].v,t[i].size);
- while(Q--){
- op=read();l=read();r=read();
- if(op==){v=read();add(l,r,v);}
- else if(op==) rev(l,r);
- else if(op==) getmax(l,r);
- //print(root);puts("");
- }
- }
BZOJ 1251: 序列终结者 [splay]的更多相关文章
- bzoj 1251序列终结者 splay 区间翻转,最值,区间更新
序列终结者 Time Limit: 20 Sec Memory Limit: 162 MBSubmit: 4594 Solved: 1939[Submit][Status][Discuss] De ...
- BZOJ 1251 序列终结者(Splay)
题目大意 网上有许多题,就是给定一个序列,要你支持几种操作:A.B.C.D.一看另一道题,又是一个序列要支持几种操作:D.C.B.A.尤其是我们这里的某人,出模拟试题,居然还出了一道这样的,真是没技术 ...
- BZOJ 1251: 序列终结者
1251: 序列终结者 Time Limit: 20 Sec Memory Limit: 162 MB Submit: 3773 Solved: 1579 [Submit][Status][Dis ...
- bzoj 1251: 序列终结者 平衡树,fhqtreap
链接 https://www.lydsy.com/JudgeOnline/problem.php?id=1251 思路 好简单的模板题 不过还是wrong了好几发 叶子节点要注意下,不能使用 遇到就不 ...
- 【BZOJ】1251: 序列终结者(splay)
http://www.lydsy.com/JudgeOnline/problem.php?id=1251 不行..为什么写个splay老是犯逗,这次又是null的mx没有赋值-maxlongint.. ...
- 1251. 序列终结者【平衡树-splay】
Description 网上有许多题,就是给定一个序列,要你支持几种操作:A.B.C.D.一看另一道题,又是一个序列 要支持几种操作:D.C.B.A.尤其是我们这里的某人,出模拟试题,居然还出了一道这 ...
- 【BZOJ1251】序列终结者 Splay
一道模板题,一直没发现自己的快速读入读不了负数,我竟然能活到现在真是万幸. #include <iostream> #include <cstdio> #define inf ...
- CODEVS 4655 序列终结者-splay(区间更新、区间翻转、区间最值)
4655 序列终结者 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 大师 Master 题解 题目描述 Description 网上有许多题,就是给定一个序列,要 ...
- [bzoj1251]序列终结者——splay
题目大意 网上有许多题,就是给定一个序列,要你支持几种操作:A.B.C.D.一看另一道题,又是一个序列 要支持几种操作:D.C.B.A.尤其是我们这里的某人,出模拟试题,居然还出了一道这样的,真是没技 ...
随机推荐
- .NET Core RC2发布在即,我们试着用记事本编写一个ASP.NET Core RC2 MVC程序
在.NET Core 1.0.0 RC2即将正式发布之际,我也应应景,针对RC2 Preview版本编写一个史上最简单的MVC应用.由于VS 2015目前尚不支持,VS Code的智能感知尚欠火候,所 ...
- IIS7禁用单个静态文件的缓存配置方法
IIS7中,想将一个经常修改的静态文件设置为不可缓存,在IIS配置界面里怎么也找不到... 一番google之后在stackoverflow里边发现了这样一段回答,最终解决了问题: just stum ...
- [摘录]第三部分 IBM文化(1)
第二十章 论公司文化如果是在20世纪90年代初期,当一个人看见或者听到“IBM”时,他会联想到什么呢?或许是“大计算机”.“个人电脑”或者“ThinkPads”.但是,他们同时也必然会想到“大公司”. ...
- android使用PullToRefresh实现上拉加载和下拉刷新效果
其实很早前就在博客园中也写过官方的下拉刷新控件SwipeRefreshLayout,但是这个控件仅仅支持下拉刷新,用起来还算可以.然而在我们实际开发应用中,很多地方都不止有下拉刷新,而且还有上拉加载的 ...
- 微服务(Microservices)—Martin Fowler【翻译】
本文转载自:http://www.cnblogs.com/liuning8023/p/4493156.html -------------------------------------------- ...
- MessageBox.Show()的各种用法
[函数] <整型> MessageBox(<字符串> Text, <字符串> Title, <整型> nType,MessageBoxIcon); [函 ...
- JavaScript原型链分析
Js之原型链 1.object 与 Object 1.object是类型,表示对象类型 2.Object是函数 2.js成员的访问规则 o.方法( ...
- C#——this关键字(1)
//我的C#是跟着猛哥(刘铁猛)(算是我的正式老师)<C#语言入门详解>学习的,微信上猛哥也给我讲解了一些不懂得地方,对于我来说简直是一笔巨额财富,难得良师! 在学习C#的时候,老师讲的示 ...
- 使用SignalR实现服务端消息推送
概述 这篇文章参考的是Server Broadcast with SignalR 2这篇教程,很不错的一篇教程,如果有兴趣的话可以查看原文,今天记录下来作为一个学习笔记,这样今后翻阅会更方便一点. 这 ...
- C# 高效编程笔记2
C# 高效编程笔记2 1.理解GetHashCode()的陷阱 (1)作用:作为基于散列集合定义键的散列值,如:HashSet<T>,Dictionary<K,V>容器等 (2 ...