【Splay】【块状链表】bzoj3223 Tyvj 1729 文艺平衡树
让蒟蒻见识到了常数大+滥用STL的危害。
<法一>很久之前的Splay
#include<cstdio>
#include<algorithm>
using namespace std;
#define maxn 110000
#define INF 2147483647
int n,m,l,r,fa[maxn],c[maxn][2],val[maxn],head,tail,root,tot,siz[maxn];
bool delta[maxn];
inline void Maintain(int x)
{
if(x)
siz[x]=siz[c[x][0]]+siz[c[x][1]]+1;
}
inline void Pushdown(int x)
{
if(x&&delta[x])
{
if(c[x][0])
delta[c[x][0]]^=true;
if(c[x][1])
delta[c[x][1]]^=true;
swap(c[x][0],c[x][1]);
delta[x]=false;
}
}
inline void NewNode(int &x,int Fa,int key)
{
x=++tot;
fa[x]=Fa;
val[x]=key;
siz[x]=1;
}
inline void Rotate(int x,bool flag)//flag指左旋还是右旋;
{
int y=fa[x];
Pushdown(x);
Pushdown(y);
c[y][!flag]=c[x][flag];
fa[c[x][flag]]=y;
if(fa[y])
c[fa[y]][c[fa[y]][1]==y]=x;
fa[x]=fa[y];
c[x][flag]=y;
fa[y]=x;
Maintain(y);
}
inline void Splay(int x,int goal)//指要将x旋转为goal节点的子节点 :双旋!!!!
{
if(!x||x==goal)
return;
int y;
Pushdown(x);
while((y=fa[x])!=goal)
{
if(fa[y]==goal)
Rotate(x,c[y][0]==x);
else
{
if((c[y][0]==x)==(c[fa[y]][0]==y))
Rotate(y,c[fa[y]][0]==y);
else
{
Rotate(x,c[y][0]==x);
y=fa[x];
}
Rotate(x,c[y][0]==x);
}
}
Maintain(x);
if(!goal)
root=x;
}
inline int Find(int &root,int key)
{
int x=root;
while(c[x][val[x]<key])
{
if(val[x]==key)
return x;
x=c[x][val[x]<key];
}
return x;
}
inline void Insert(int &root,int key)
{
if(!root)
{
NewNode(root,0,key);
return;
}
int x=Find(root,key);
if(val[x]==key)
{
Splay(x,0);
return;
}
NewNode(c[x][val[x]<key],x,key);
Splay(c[x][val[x]<key],0);
}
inline int Kth(int &root,int K)
{
int x=root;
while(1)
{
Pushdown(x);
int Siz0=siz[c[x][0]];
if(K<=Siz0)
x=c[x][0];
else if(K==Siz0+1)
break;
else
{
K-=(Siz0+1);
x=c[x][1];
}
}
return x;
}
inline void Print(int x)
{
if(!x)
return;
Pushdown(x);
Print(c[x][0]);
printf("%d ",val[x]);
Print(c[x][1]);
Maintain(x);
return;
}
int main()
{
scanf("%d%d",&n,&m);
Insert(root,0);
for(int i=1;i<=n;i++)
Insert(root,i);
Insert(root,n+1);
for(int i=1;i<=m;i++)
{
scanf("%d%d",&l,&r);
Splay(Kth(root,l),0);
Splay(Kth(root,r+2),root);
delta[c[c[root][1]][0]]^=true;
Pushdown(c[c[root][1]][0]);
}
Splay(Kth(root,1),0);
Splay(Kth(root,n+2),root);
Print(c[c[root][1]][0]);
return 0;
}
<法二>块状链表维护翻转标记,维护块形态。50'
#include<cstdio>
#include<list>
#include<vector>
#include<algorithm>
#include<cmath>
using namespace std;
int f,c;
inline void Read(int &x){
c=0;f=1;
for(;c<'0'||c>'9';c=getchar())if(c=='-')f=-1;
for(x=0;c>='0'&&c<='9';c=getchar())(x*=10)+=(c-'0');
x*=f;
}
void Write(int x){
if(x<10)putchar(x+'0');
else{Write(x/10);putchar(x%10+'0');}
}
typedef vector<int>::iterator VER;
struct Node
{
bool Reversed;
vector<int>v;
Node(){Reversed=0;}
};
list<Node>List;
int n,m,tmp[100001],x,y,sz,L,R;
typedef list<Node>::iterator LER;
typedef pair<LER,VER> Point;
inline Point Find(const int &p)
{
int cnt=0; LER i=List.begin();
for(;i!=List.end();++i)
{
cnt+=(*i).v.size();
if(cnt>=p)
{
cnt-=(*i).v.size();
for(VER j=(*i).v.begin();j!=(*i).v.end();++j)
if((++cnt)==p)
return make_pair(i,j);
}
}
--i; return make_pair(i,(*i).v.end());
}
void Makeblock()
{
sz=sqrt(n); int tot=1; if(!sz) sz=1;
for(;tot*sz<n;++tot)
{
LER End=List.insert(List.end(),Node());
(*End).v.assign(tmp+(tot-1)*sz+1,tmp+tot*sz+1);
}
LER End=List.insert(List.end(),Node());
(*End).v.assign(tmp+(tot-1)*sz+1,tmp+n+1);
}
inline void pushdown(const LER &p)
{
if((*p).Reversed)
{
reverse((*p).v.begin(),(*p).v.end());
(*p).Reversed=0;
}
}
inline LER Split(const int &p)
{
Point Pos=Find(p);
pushdown(Pos.first);
if(Pos.second==(*Pos.first).v.begin()) return Pos.first;
LER newB=List.insert(Pos.first,Node());
(*newB).v.assign((*Pos.first).v.begin(),Pos.second);
(*Pos.first).v.erase((*Pos.first).v.begin(),Pos.second);
return Pos.first;
}
void Printans()
{
for(LER i=List.begin();i!=List.end();++i)
{
if((*i).Reversed)
for(VER j=(*i).v.end()-1;j>=(*i).v.begin();--j)
Write(*j),putchar(' ');
else
for(VER j=(*i).v.begin();j!=(*i).v.end();++j)
Write(*j),putchar(' ');
}
puts("");
}
inline void Merge(LER &a,LER &b)
{
pushdown(a);
pushdown(b);
(*a).v.insert((*a).v.begin(),(*b).v.begin(),(*b).v.end());
List.erase(b);
}
inline void MaintainList()
{
LER curB=List.begin();
while(curB!=List.end())
{
LER nexB=curB; ++nexB;
while(nexB!=List.end()
&&(*curB).v.size()+(*nexB).v.size()<=(sz<<1))
{
Merge(nexB,curB);
curB=nexB;
++nexB;
}
++curB;
}
}
inline void Reverse()
{
Read(L); Read(R);
if(L==R) return;
Point Pl=Find(L),Pr=Find(R);
if(Pl.first==Pr.first)
{
pushdown(Pl.first);
reverse(Pl.second,++Pr.second);
return;
}
LER Lb=Split(L),Rb=Split(R+1);
for(LER i=Lb;i!=Rb;++i)
(*i).Reversed^=1;
reverse(Lb,Rb);
MaintainList();
}
int main()
{
Read(n);
Read(m);
for(int i=1;i<=n;++i)
tmp[i]=i;
Makeblock();
for(int i=1;i<=m;++i)
Reverse();
Printans();
return 0;
}
【Splay】【块状链表】bzoj3223 Tyvj 1729 文艺平衡树的更多相关文章
- [BZOJ3223]Tyvj 1729 文艺平衡树
		
[BZOJ3223]Tyvj 1729 文艺平衡树 试题描述 您需要写一种数据结构(可参考题目标题),来维护一个有序数列,其中需要提供以下操作:翻转一个区间,例如原有序序列是5 4 3 2 1,翻转区 ...
 - BZOJ3223: Tyvj 1729 文艺平衡树 [splay]
		
3223: Tyvj 1729 文艺平衡树 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 3595 Solved: 2029[Submit][Sta ...
 - bzoj3223 Tyvj 1729 文艺平衡树(Splay Tree+区间翻转)
		
3223: Tyvj 1729 文艺平衡树 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 2202 Solved: 1226[Submit][Sta ...
 - bzoj3223: Tyvj 1729 文艺平衡树 splay裸题
		
splay区间翻转即可 /************************************************************** Problem: 3223 User: walf ...
 - 【Splay】bzoj3223 Tyvj 1729 文艺平衡树
		
#include<cstdio> #include<iostream> #include<cstring> #include<algorithm> #i ...
 - 2018.08.05 bzoj3223: Tyvj 1729 文艺平衡树(非旋treap)
		
传送门 经典的平衡树问题,之前已经用splay写过一次了,今天我突发奇想,写了一发非旋treap的版本,发现挺好写的(虽然跑不过splay). 代码: #include<bits/stdc++. ...
 - BZOJ3223——Tyvj 1729 文艺平衡树
		
1.题目大意:维护序列,只有区间翻转这个操作 2.分析:splay的经典操作就是实现区间翻转,就是在splay中有一个标记,表示这个区间被翻转了 然后就是记得各种的操作访问某个点时,记得下传,顺便交换 ...
 - BZOJ3223: Tyvj 1729 文艺平衡树 无旋Treap
		
一开始光知道pushdown却忘了pushup......... #include<cstdio> #include<iostream> #include<cstring ...
 - BZOJ 3223: Tyvj 1729 文艺平衡树(splay)
		
速度居然进前十了...第八... splay, 区间翻转,用一个类似线段树的lazy标记表示是否翻转 ------------------------------------------------- ...
 
随机推荐
- 论文笔记《Spatial Memory for Context Reasoning in Object Detection》
			
好久不写论文笔记了,不是没看,而是很少看到好的或者说值得记的了,今天被xinlei这篇paper炸了出来,这篇被据老大说xinlei自称idea of the year,所以看的时候还是很认真的,然后 ...
 - [poj 3281]最大流+建图很巧妙
			
题目链接:http://poj.org/problem?id=3281 看了kuangbin大佬的思路,还用着kuangbin板子orz http://www.cnblogs.com/kuangb ...
 - jQuery知识点:attr与prop的区别
			
做项目时遇到个莫名的问题,全选的时候仅第一次有效,再次点击全选按钮是无效了,查了查原因,看到篇很不错的文章,问题出在jquery中的attr属性上,这里做下笔记. 原文链接:http://www.cn ...
 - apply()和call()
			
每个函数都包含俩个非继承而来的方法:apply() 和 call(),这俩个方法的用途都是在特定的作用域中调用函数,实际上等于设置函数体内this对象的值,以扩充函数赖以运行的作用域.一般来讲,thi ...
 - 编写一个 Chrome 浏览器扩展程序
			
浏览器扩展允许我们编写程序来实现对浏览器元素(书签.导航等)以及对网页元素的交互, 甚至从 web 服务器获取数据,以 Chrome 浏览器扩展为例,扩展文件包括: 一个manifest文件(主文件, ...
 - 拉格朗日乘数法 和 KTT条件
			
预备知识 令 \(X\) 表示一个变量组(向量) \((x_1, x_2, \cdots, x_n)\) 考虑一个处处可导的函数 \(f(X)\), 为了方便描述, 这里以二元函数为例 对于微分, 考 ...
 - 【bzoj2219-数论之神】求解x^a==b(%n)-crt推论-原根-指标-BSGS
			
http://www.lydsy.com/JudgeOnline/problem.php?id=2219 弄了一个晚上加一个午休再加下午一个钟..终于ac..TAT 数论渣渣求轻虐!! 题意:求解 x ...
 - jzoj2701 【GDKOI2012模拟02.01】矩阵
			
传送门:https://jzoj.net/senior/#main/show/2701 [题目大意] 给出矩阵A,求矩阵B,使得
 - cobalt strike使用笔记
			
启动: ./teamserver 192.168.74.1 admin #启动cs服务器.admin为密码. 监听器: windows/beacon_dns/reverse_dns_txtwindow ...
 - algorithm ch15  FastWay
			
这是DP最基础的一个问题,刚开始学习这一块,实现了一下,不要黑我巨长的参数表,新手. 代码如下: void FastWay(int l1[], int l2[], int e1, int e2, in ...