洛谷P3391 文艺平衡树 (Splay模板)
模板题。
注意标记即可,另外,涉及区间翻转操作,记得设立首尾哨兵。
1 #include<bits/stdc++.h>
2 using namespace std;
3 const int Maxn=0x3f3f3f3f;
4 const int N=1e5+5;
5 int lc[N],rc[N],fa[N],sze[N],vi[N],pos[N],a[N];
6 int n,m,x,y,rt,T;
7
8 inline int get(){//快读
9 char ch;bool f=false;int res=0;
10 while(((ch=getchar())<'0'||ch>'9')&&ch!='-');
11 if(ch=='-') f=true;
12 else res=ch-'0';
13 while((ch=getchar())>='0'&&ch<='9')
14 res=(res<<3)+(res<<1)+ch-'0';
15 return f?~res+1:res;
16 }
17
18 inline bool Wrt(const int&x)
19 {
20 return rc[fa[x]]==x;
21 }
22
23 inline void down(const int &x){//下传标记
24 if(x&&pos[x]){
25 pos[lc[x]]^=1;
26 pos[rc[x]]^=1;
27 swap(lc[x],rc[x]);
28 pos[x]=0;
29 }
30 }
31
32 inline void push(int x){
33 sze[x]=sze[lc[x]]+sze[rc[x]]+1;
34 }
35
36 inline int build(int lst,int l,int r){//lst该节点的祖先编号
37 if(l>r) return 0;
38 int mid=(l+r)>>1,x=++T;
39 fa[x]=lst;pos[x]=0;vi[x]=a[mid];
40 lc[x]=build(x,l,mid-1);
41 rc[x]=build(x,mid+1,r);
42 push(x);
43 return x;
44 }
45
46 inline void rot(int x){//单旋
47 int y=fa[x],z=fa[y];
48 down(y);down(x);//下传标记
49 int b=(lc[y]==x)?rc[x]:lc[x];
50 fa[x]=z;fa[y]=x;
51 if(b) fa[b]=y;
52 if(z) (y==lc[z]?lc[z]:rc[z])=x;
53 if(x==lc[y]) rc[x]=y,lc[y]=b;
54 else lc[x]=y,rc[y]=b;
55 push(y);push(x);//更新
56 }
57
58 inline void splay(int x,int tar){
59 while(fa[x]!=tar){
60 if(fa[fa[x]]!=tar)
61 Wrt(x)==Wrt(fa[x])?rot(fa[x]):rot(x);
62 rot(x);
63 }
64 if(!tar) rt=x;
65 }
66
67 inline int Find(int k){//查找第k个数
68 int x=rt,y=k;
69 while(x){
70 down(x);
71 if(y<=sze[lc[x]]) x=lc[x];
72 else{
73 y-=sze[lc[x]]+1;
74 if(!y) return x;
75 x=rc[x];
76 }
77 }
78 }
79
80 /*inline void put(int x){//快输
81 if(x<0){
82 x=~x+1;
83 putchar('-');
84 }
85 if(x>9) put(x/10);
86 putchar(x%10+48);
87 }*/
88
89 inline void Print(int x){
90 down(x);
91 if(lc[x]) Print(lc[x]);
92 if(vi[x]!=-Maxn&&vi[x]!=Maxn)
93 // put(vi[x]),putchar(' ');//快输
94 cout<<vi[x]<<" ";
95 if(rc[x]) Print(rc[x]);
96 }
97
98 int main(){
99 n=get();m=get();
100 a[1]=-Maxn;a[n+2]=Maxn;
101 for(int i=1;i<=n;i++) a[i+1]=i;
102 rt=build(0,1,n+2);
103 while(m--){
104 int tx=Find(get());
105 int ty=Find(get()+2);
106 splay(tx,0);
107 splay(ty,tx);
108 pos[lc[rc[rt]]]^=1;
109 }
110 return Print(rt),0;
111 }
洛谷P3391 文艺平衡树 (Splay模板)的更多相关文章
- [洛谷P3391] 文艺平衡树 (Splay模板)
初识splay 学splay有一段时间了,一直没写...... 本题是splay模板题,维护一个1~n的序列,支持区间翻转(比如1 2 3 4 5 6变成1 2 3 6 5 4),最后输出结果序列. ...
- 洛谷P3391文艺平衡树(Splay)
题目传送门 转载自https://www.cnblogs.com/yousiki/p/6147455.html,转载请注明出处 经典引文 空间效率:O(n) 时间效率:O(log n)插入.查找.删除 ...
- BZOJ3223/洛谷P3391 - 文艺平衡树
BZOJ链接 洛谷链接 题意 模板题啦~2 代码 //文艺平衡树 #include <cstdio> #include <algorithm> using namespace ...
- BZOJ3224/洛谷P3391 - 普通平衡树(Splay)
BZOJ链接 洛谷链接 题意简述 模板题啦~ 代码 //普通平衡树(Splay) #include <cstdio> int const N=1e5+10; int rt,ndCnt; i ...
- 洛谷 P3391 文艺平衡树
题目描述 您需要写一种数据结构(可参考题目标题),来维护一个有序数列,其中需要提供以下操作:翻转一个区间,例如原有序序列是5 4 3 2 1,翻转区间是[2,4]的话,结果是5 2 3 4 1 --b ...
- 洛谷.3391.文艺平衡树(fhq Traep)
题目链接 //注意反转时先分裂r,因为l,r是针对整棵树的排名 #include<cstdio> #include<cctype> #include<algorithm& ...
- 洛谷 P3391 【模板】文艺平衡树(Splay)
题目背景 这是一道经典的Splay模板题——文艺平衡树. 题目描述 您需要写一种数据结构(可参考题目标题),来维护一个有序数列,其中需要提供以下操作:翻转一个区间,例如原有序序列是5 4 3 2 1, ...
- 【阶梯报告】洛谷P3391【模板】文艺平衡树 splay
[阶梯报告]洛谷P3391[模板]文艺平衡树 splay 题目链接在这里[链接](https://www.luogu.org/problemnew/show/P3391)最近在学习splay,终于做对 ...
- luoguP3391[模板]文艺平衡树(Splay) 题解
链接一下题目:luoguP3391[模板]文艺平衡树(Splay) 平衡树解析 这里的Splay维护的显然不再是权值排序 现在按照的是序列中的编号排序(不过在这道题目里面就是权值诶...) 那么,继续 ...
随机推荐
- CentOS删除桌面环境
公司有几台虚拟机安装的是CentOS7的桌面环境,平时也是用终端访问,于是在服务器卡住需要重启时,顺便就把桌面环境给卸载了:测试了好多方法均不成功,最终找到了可行的方式,以此记录: [root@yun ...
- .netcore 定制化项目开发的思考和实现
今年年初进了一家新公司,进入之后一边维护老项目一边了解项目流程,为了接下来的项目重做积累点经验. 先说下老项目吧,.net fx 3.5+oracle...... 在实际维护中逐渐发现,老项目有标准版 ...
- linux常用命令和快捷键收集
find / -name php #查找根目录下所有包含 php 字符的文件和目录 find / -ctime 1 #查找最近一天下载的文件和目录 yum install lrzsz #安装上传下载组 ...
- Java8新特性: lambda 表达式介绍
一.lambda 表达式介绍 lambda 表达式是 Java 8 的一个新特性,可以取代大部分的匿名内部类,简化了匿名委托的使用,让你让代码更加简洁,优雅. 比较官方的定义是这样的: lambda ...
- cad工具快速选择特性里面是空的解决方法
工具-选项-文件中,支持文件搜索路径中 添加,再浏览,找到"C:\Program Files\Common Files\Autodesk Shared"确定就OK了.
- eplan中数据库运行提速
access,sql,是指部件库的存储方式,eplan支持两种方式即Microsoft Office access,Microsoft SQL Server,可以通过这两种方式打开部件库,如果要打开数 ...
- 2019国家集训队论文《整点计数》命题报告 学习笔记/Min25
\(2019\)国家集训队论文<整点计数>命题报告 学习笔记/\(Min25\) 补了个大坑 看了看提交记录,发现\(hz\)的\(xdm\)早过了... 前置知识,\(HAOI\)< ...
- JavaScript 权威指南-学习笔记(一)
本文所有教程及源码.软件仅为技术研究.不涉及计算机信息系统功能的删除.修改.增加.干扰,更不会影响计算机信息系统的正常运行.不得将代码用于非法用途,如侵立删! ## JavaScript 权威指南-学 ...
- 搞定面试官 - MySQL 中你知道如何计算一个索引的长度嘛?
大家好,我是程序员啊粥. 今天给大家分享一个我遇到过的比较少见的面试题,那就是 MySQL 中如何计算一个索引的长度. 说实话,我第一次遇到这个问题的时候想当然的以为索引长度就是我们建表时定义的字段长 ...
- Linux的NFS的配置
快速代码 # nfs的Server配置文件和配置方法 echo '/newnfs 192.168.3.*rw,sync,no_root_squash)' >> /etc/exports # ...