【BZOJ 3223】文艺平衡树 模板题
就是打个翻转标记,下推标记时记得交换左右孩子指针,查询kth和中序遍历输出时也记得要下推标记同时交换指针,二者不可缺!←这是易错点
仿陈竞潇学长模板的代码:
#include<cctype>
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
struct node{
node();
node *ch[2],*fa;
short reversal;
short pl(){return this==fa->ch[1];}
int d,sum;
void push(); void count();
}*null;
int N,M;
node::node(){ch[0]=ch[1]=fa=null;reversal=sum=d=0;}
void node::push(){
if (this==null) return;
if (reversal==1){
reversal=0;
ch[0]->reversal^=1;
ch[1]->reversal^=1;
node *k=ch[0];
ch[0]=ch[1];
ch[1]=k;
}
}
void node::count(){
sum=ch[0]->sum+ch[1]->sum+1;
}
namespace Splay{
node *ROOT;
node *build(int l=1,int r=N){
if (l>r) return null;
int mid=(l+r)>>1;
node *ro=new node;
ro->d=mid;
ro->ch[0]=build(l,mid-1);
ro->ch[1]=build(mid+1,r);
ro->ch[0]->fa=ro;
ro->ch[1]->fa=ro;
ro->count();
return ro;
}
void Build(){
null=new node;
*null=node();
ROOT=build();
ROOT->count();
}
void rotate(node *k){
node *r=k->fa; if (r==null||k==null) return;
r->push(); k->push();
int x=k->pl()^1;
r->ch[x^1]=k->ch[x];
r->ch[x^1]->fa=r;
if (r->fa==null) ROOT=k;
else r->fa->ch[r->pl()]=k;
k->fa=r->fa;
r->fa=k;
k->ch[x]=r;
r->count(); k->count();
}
void splay(node *r,node *tar=null){
for (;r->fa!=tar;rotate(r))
if (r->fa->fa!=tar)rotate(r->pl()==r->fa->pl()?r->fa:r);
r->push();
}
node *kth(int x){
node *r=ROOT;
while (r!=null){
r->push();
if (r->ch[0]->sum>=x) r=r->ch[0];
else if (r->ch[0]->sum+1>=x) return r;
else x-=r->ch[0]->sum+1,r=r->ch[1];
}return null;
}
void rollingover(int ll,int rr){
node *ln=kth(ll-1),*rn=kth(rr+1),*r;
if ((ln==null)&&(rn==null)) r=ROOT;
else if (ln==null){
splay(rn); r=ROOT->ch[0];
}else if (rn==null){
splay(ln); r=ROOT->ch[1];
}else{
splay(ln); splay(rn,ROOT);
r=ROOT->ch[1]->ch[0];
}r->reversal=r->reversal^1;
}
void AC(node *r=ROOT){
if (r==null) return;
r->push();
AC(r->ch[0]);
printf("%d ",r->d);
AC(r->ch[1]);
}
}
int getint()
{
char c;
while (!isdigit(c=getchar()));
int a=c-'0';
while (isdigit(c=getchar()))
a=a*10+c-'0';
return a;
}
int main()
{
N=getint();M=getint();
Splay::Build();
while (M--){
int l=getint(),r=getint();
Splay::rollingover(l,r);
}
Splay::AC();
return 0;
}
自己写的62行简洁代码:
#include<cstdio>
#include<algorithm>
#define read(x) x=getint()
using namespace std;
inline int getint(){char c;int ret=0;for(c=getchar();c<'0'||c>'9';c=getchar());for(;c>='0'&&c<='9';c=getchar())ret=ret*10+c-'0';return ret;}
struct node{
node();
node *fa,*ch[2];
int d,sum;
bool rev;
bool pl() {return this->fa->ch[1]==this;}
void setc(node *r,bool c) {r->fa=this; this->ch[c]=r;}
void push() {if (rev){swap(ch[0],ch[1]);ch[0]->rev^=1;ch[1]->rev^=1;rev=0;}}
void count() {sum=ch[0]->sum+ch[1]->sum+1;}
}*ROOT,*null;
node::node(){fa=ch[0]=ch[1]=null;d=sum=rev=0;}
int n,m;
inline node *build(int l,int r){
if (l>r) return null; int mid=(l+r)>>1; node *k=new node;
k->ch[0]=build(l,mid-1); k->ch[1]=build(mid+1,r);
if (k->ch[0]!=null) k->ch[0]->fa=k; if (k->ch[1]!=null) k->ch[1]->fa=k;
k->d=mid; k->count(); return k;
}
inline void Build() {null=new node;*null=node();ROOT=build(1,n);}
inline void rotate(node *r){
node *f=r->fa; bool c=r->pl();
if (f!=ROOT) f->fa->setc(r,f->pl());
else r->fa=null,ROOT=r;
f->setc(r->ch[!c],c); r->setc(f,!c);
f->count();
}
inline void update(node *r) {if (r!=null) update(r->fa); r->push();}
inline void splay(node *r,node *tar=null){
update(r);
for(;r->fa!=tar;rotate(r)) if (r->fa->fa!=tar) rotate(r->fa->pl()==r->pl()?r->fa:r);
r->count();
}
inline node *kth(int x){
if ((x==0)||(x==n+1)) return null;
node *r=ROOT;
while (1){
r->push();
if (r->ch[0]->sum>=x) r=r->ch[0];
else if (r->ch[0]->sum+1>=x) return r;
else {x-=r->ch[0]->sum+1; r=r->ch[1];}
}
}
inline void reversal(int l,int r){
node *ll=kth(l-1),*rr=kth(r+1);
if ((ll==null)&&(rr==null)) ROOT->rev^=1;
else if (ll==null) splay(rr),ROOT->ch[0]->rev^=1;
else if (rr==null) splay(ll),ROOT->ch[1]->rev^=1;
else splay(ll),splay(rr,ROOT),rr->ch[0]->rev^=1;
}
inline void AC(node *r) {if (r==null) return; r->push(); AC(r->ch[0]); printf("%d ",r->d); AC(r->ch[1]);}
int main(){
read(n); read(m); Build();
int l,r;
while (m--) {read(l); read(r); reversal(l,r);}
AC(ROOT);
return 0;
}
然后就可以了
【BZOJ 3223】文艺平衡树 模板题的更多相关文章
- [题解]bzoj 3223 文艺平衡树
3223: Tyvj 1729 文艺平衡树 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 3884 Solved: 2235[Submit][Sta ...
- bzoj 3223 文艺平衡树 - Splay
3223: Tyvj 1729 文艺平衡树 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 3884 Solved: 2235[Submit][Sta ...
- BZOJ 3223 文艺平衡树 [codevs3303翻转区间]
AC通道:http://www.lydsy.com/JudgeOnline/problem.php?id=3223 通道2:http://codevs.cn/problem/3303/ 题目分析: 我 ...
- BZOJ 3223 文艺平衡树
Description 您需要写一种数据结构(可参考题目标题),来维护一个有序数列,其中需要提供以下操作:翻转一个区间,例如原有序序列是5 4 3 2 1,翻转区间是[2,4]的话,结果是5 2 ...
- bzoj 3223 文艺平衡树 splay 区间翻转
Tyvj 1728 普通平衡树 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 17715 Solved: 7769[Submit][Status][ ...
- bzoj 3223 文艺平衡树 Splay 打标志
是NOI2003Editor的一个子任务 #include <cstdio> #include <vector> #define maxn 100010 using names ...
- HDU 4006 The kth great number 优先队列、平衡树模板题(SBT)
The kth great number Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65768/65768 K (Java/Oth ...
- [bzoj3224]普通平衡树/3223文艺平衡树
这是一道很普通的题.. 最近花了很多时间来想要去干什么,感觉自己还是太拿衣服 做这道题是因为偶尔看到了lavender的blog和她的bzoj早期AC记录,就被题目深深地吸引到了,原因有二: 自己sp ...
- BZOJ 2724 蒲公英 | 分块模板题
题意 给出一个序列,在线询问区间众数.如果众数有多个,输出最小的那个. 题解 这是一道分块模板题. 一个询问的区间的众数,可能是中间"整块"区间的众数,也可能是左右两侧零散的数中的 ...
随机推荐
- selenium如何跳转到iframe
处理iframe,selenium提供了3中方法: 1.html的frame有id,传入id 2.html的frame有name,传入name 3.先找到iframe的元素,再传入该元素对象 跳出if ...
- leetcode-Spiral Matrix II 螺旋矩阵2之python大法好,四行就搞定,你敢信?
Spiral Matrix II 螺旋矩阵 Given an integer n, generate a square matrix filled with elements from 1 to n2 ...
- Android Sdk 和ADT Eclipse安装配置步骤
由于我们之前下载的jdk版本是1.6的,所以后面的andriod sdk等版本需要相对应.安装文件我都放在云盘里面,需要的可以下载 一:如果单独安装每一个软件,先期需要下载的软件包如下: 1.JDK ...
- Android代码优化----PullToRefresh+universal-image-loader实现从网络获取数据并刷新
[声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/4 ...
- java 21 - 9 复制图片的4种方式
需求:复制图片 分析: 因为图片我们用记事本打开后无法读懂,所以用字节流 并且字节流复制有4种方式,所以我们尝试4种方式. 推荐第四种:缓冲字节流一次读取一个字节数组 首先写main方法: publi ...
- Android 动态加载 (三) PAK 详解
pak文件经常出现于游戏的安装目录中,其实pak文件是一种特殊的游戏压缩文件,用于压缩声音.图片等资料.由于pak文件专门针对游戏设计文件结构,pak文件就是将多个文件(图片.音乐.文本)打包为一个单 ...
- tp2.2.2新特点
1.不需要在配置文件中配置URL_MODEL变量就可以用普通模式和路径模式及兼容模式访问URL,但重写模式不可以. 2.当访问的URL地址没有指明具体动作(控制器里的方法)的时候,如果该控制器对应的视 ...
- onmeasure
UNSPECIFIE : 0 [0x0],未加规定的,表示没有给子view添加任何规定. EXACTLY : 1073741824 [0x40000000],精确的,表示父view为子view确定精确 ...
- 通信vue2.0组件
vue2.0组件通信各种情况总结与实例分析 Props在vue组件中各种角色总结 在Vue中组件是实现模块化开发的主要内容,而组件的通信更是vue数据驱动的灵魂,现就四种主要情况总结如下: 使用p ...
- php基础19:文件
<?php //1.打开文件的更好的方法是通过 fopen() 函数.此函数为您提供比 readfile() 函数更多的选项. //fopen() 的第一个参数包含被打开的文件名,第二个参数规定 ...