题目大意:略

splay维护区间翻转裸题,为了减少不必要的麻烦,多插入两个点,分别是0和n+1

每次找区间的第K个值,就在splay上二分即可

顺便学了一下splay的完美建树,而且splay有一些小函数可以宏定义或者用inline,跑得飞快

最后跑一遍中序遍历即可

 #include <cstdio>
#include <cstring>
#include <algorithm>
#define N 100100
#define il inline
#define ll long long
#define root d[0].ch[1]
#define con(x,ff,p) d[x].fa=ff,d[ff].ch[p]=x
#define idf(x) d[d[x].fa].ch[0]==x?0:1
#define lb(x) (x&(-x))
using namespace std; int n,m,cnt;
struct SPLAY{
int fa,ch[],id,sum,mrk;
}d[N<<];
il void pushup(int x) {d[x].sum=d[d[x].ch[]].sum+d[d[x].ch[]].sum+;}
il void pushdown(int x)
{
if(!d[x].mrk) return;
swap(d[x].ch[],d[x].ch[]);
d[x].mrk=;
d[d[x].ch[]].mrk^=;
d[d[x].ch[]].mrk^=;
}
il void rot(int x)
{
int y=d[x].fa;int ff=d[y].fa;
int px=idf(x);int py=idf(y);
con(d[x].ch[px^],y,px);
con(y,x,px^);
con(x,ff,py);
pushup(y),pushup(x);
}
void splay(int x,int to)
{
to=d[to].fa;
int y,px,py;
while(d[x].fa!=to)
{
y=d[x].fa;
px=idf(y),py=idf(x);
if(d[y].fa==to) rot(x);
else if(py==px){
rot(y);
rot(x);
}else{
rot(x);
rot(x);
}
}
}
int Find(int w)
{
int x=root;
while(x)
{
pushdown(x);
if(d[d[x].ch[]].sum>=w)
{
x=d[x].ch[];
continue;
}
w-=d[d[x].ch[]].sum;
if(w==) return x;
w--,x=d[x].ch[];
}
return ;
}
int build(int ff,int l,int r)
{
if(l>r) return ;
int x=++cnt;
int mid=(l+r)>>;
d[x].id=mid-,d[x].fa=ff,d[x].sum=;
d[x].ch[]=build(x,l,mid-);
d[x].ch[]=build(x,mid+,r);
pushup(x);
return x;
}
void Print(int x)
{
pushdown(x);
if(d[x].ch[]) Print(d[x].ch[]);
if(d[x].id!=&&d[x].id!=n+) printf("%d ",d[x].id);
if(d[x].ch[]) Print(d[x].ch[]);
}
int main()
{
//freopen("testdata.in","r",stdin);
scanf("%d%d",&n,&m);
int x,y;
root=build(,,n+);
for(int i=;i<=m;i++){
scanf("%d%d",&x,&y);
if(x==y) continue;
int xx=Find(x);
splay(xx,root);
int yy=Find(y+);
splay(yy,d[root].ch[]);
d[d[d[root].ch[]].ch[]].mrk^=;
}
Print(root);
return ;
}

最新文章

  1. 小米网css3导航下拉菜单代码
  2. 【QT】C++ GUI Qt4 学习笔记1
  3. C#中服务端接受前端JSON字符串转换成字典集合
  4. 干净的停止tomcat/java应用程序
  5. 简单聊下IO复用
  6. zookeeper系列之一—zookeeper入门
  7. HDU5093——Battle ships(最大二分匹配)(2014上海邀请赛重现)
  8. linux中挂载硬盘报错(you must specify the filesystem type)
  9. 华为OJ之最长公共子序列
  10. Spring异常处理@ExceptionHandler
  11. MBR和GPT概要学习
  12. Linux管理日记(一)
  13. Redis hash结构
  14. 20172306 《Java程序设计与数据结构》第七周学习总结
  15. 浅谈http协议六种请求方法,get、head、put、delete、post、options区别
  16. 《剑指offer》第十三题(机器人的运动范围)
  17. 【Codeforces858F】Wizard&#39;s Tour [构造]
  18. Hibernate5笔记3--详解Hibernate的API
  19. 留言板(初学者使用js实现)
  20. C++练习 | 创建并倒序输出不带头结点的链表

热门文章

  1. 报错The jarsigner could not be found. Make sure to run with the build with a JDK。的解决方法
  2. Project Euler 31 1000-digit Fibonacci number( DP )
  3. mysql数据库增量恢复
  4. Linux 密码的暴力破解
  5. POJ 2157 How many ways??
  6. 多个API接口
  7. BA-siemens-PXM液晶面板
  8. 使用postman 测试restful接口
  9. HDU 5167
  10. ym——物联网入口之中的一个Android蓝牙4.0