BZOJ 3223: Tyvj 1729 文艺平衡树-Splay树(区间翻转)模板题

3223: Tyvj 1729 文艺平衡树

Time Limit: 10 Sec  Memory Limit: 128 MB
Submit: 6881  Solved: 4213
[Submit][Status][Discuss]

Description

您需要写一种数据结构(可参考题目标题),来维护一个有序数列,其中需要提供以下操作:翻转一个区间,例如原有序序列是5 4 3 2 1,翻转区间是[2,4]的话,结果是5 2 3 4 1 

Input

第一行为n,m n表示初始序列有n个数,这个序列依次是(1,2……n-1,n)  m表示翻转操作次数
接下来m行每行两个数[l,r] 数据保证 1<=l<=r<=n  

Output

 

输出一行n个数字,表示原始序列经过m次变换后的结果 

 

Sample Input

5 3

1 3

1 3

1 4

Sample Output

4 3 2 1 5

HINT

 



N,M<=100000

 

 

 

模板题,区间翻转问题

延时标记的作用是优化,如果一个区间翻转之后再翻转回来,用延时标记就可以优化,不必再翻转。比如翻转[1,4],再翻转[1,4],就可以延时标记优化。

其他的代码里写了注释。

 

代码:

  1 #include<iostream>
  2 #include<cstdio>
  3 #include<cstring>
  4 #include<algorithm>
  5 #include<bitset>
  6 #include<cassert>
  7 #include<cctype>
  8 #include<cmath>
  9 #include<cstdlib>
 10 #include<ctime>
 11 #include<deque>
 12 #include<iomanip>
 13 #include<list>
 14 #include<map>
 15 #include<queue>
 16 #include<set>
 17 #include<stack>
 18 #include<vector>
 19 using namespace std;
 20 typedef long long ll;
 21 
 22 const double PI=acos(-1.0);
 23 const double eps=1e-6;
 24 const ll mod=1e9+7;
 25 const int inf=0x3f3f3f3f;
 26 const int maxn=1e5+10;
 27 const int maxm=100+10;
 28 #define ios ios::sync_with_stdio(false);cin.tie(0);cout.tie(0);
 29 
 30 /*
 31 将当前排名为l-1 +1 的节点转到根
 32 将当前排名为r+2的节点转到根的右子树的根节点
 33 则根的右子树的根节点的左子树为所求区间
 34 直接打标记就可以了
 35 */
 36 
 37 int n,m,sz,rt,pre[maxn],l,r,ch[maxn][2],data[maxn],size[maxn],rev[maxn];
 38 
 39 //在爸爸节点打上标记,然后进行下放,如果进行了两次相反的翻转,lazy标记就会消失,这样就减少了翻转次数达到优化
 40 
 41 void pushup(int k)//要先pushup儿子才能pushup爸爸
 42 {
 43     size[k]=size[ch[k][0]]+size[ch[k][1]]+1;//当前节点的size为左子树+右子树+自己
 44 }
 45 
 46 void pushdown(int k)//要先pushdown爸爸才能pushdown儿子
 47 {
 48     int l=ch[k][0],r=ch[k][1];//左儿子和右儿子
 49     if(rev[k]){//翻转区间
 50         swap(ch[k][0],ch[k][1]);//翻转左右儿子
 51         rev[l]^=1;rev[r]^=1;//标记下传
 52         rev[k]=0;//当前节点标记去掉
 53     }
 54 }
 55 
 56 void rotate(int x,int &k)//翻转操作
 57 {
 58     int y=pre[x],z=pre[y],l,r;
 59     if(ch[y][0]==x) l=0;
 60     else l=1;
 61     r=l^1;
 62     if(y==k) k=x;
 63     else{if(ch[z][0]==y) ch[z][0]=x;else ch[z][1]=x;}
 64     pre[x]=z;pre[y]=x;pre[ch[x][r]]=y;
 65     ch[y][l]=ch[x][r];ch[x][r]=y;
 66     pushup(y);pushup(x);
 67 }
 68 
 69 void splay(int x,int &k)//splay到目标状态
 70 {
 71     while(x!=k){
 72         int y=pre[x],z=pre[y];
 73         if(y!=k){
 74             if(ch[y][0]==x^ch[z][0]==y)rotate(x,k);
 75             else rotate(y,k);
 76         }
 77         rotate(x,k);
 78     }
 79 }
 80 
 81 int find(int k,int rank)
 82 {
 83     pushdown(k);//有标记就pushdown
 84     int l=ch[k][0],r=ch[k][1];
 85     if(size[l]+1==rank) return k;
 86     else if(size[l]>=rank) return find(l,rank);
 87     else return find(r,rank-size[l]-1);
 88 }
 89 
 90 void change(int l,int r)
 91 {
 92     int x=find(rt,l),y=find(rt,r+2);
 93     splay(x,rt);splay(y,ch[x][1]);
 94     int z=ch[y][0];
 95     rev[z]^=1;
 96 }
 97 
 98 void build(int l,int r,int f)
 99 {
100     if(l>r) return;
101     int now=data[l],last=data[f];
102     if(l==r){
103         pre[now]=last;
104         size[now]=1;
105         if(l<f) ch[last][0]=now;
106         else ch[last][1]=now;
107         return;
108     }
109 
110     int mid=(l+r)>>1;
111     now=data[mid];
112     build(l,mid-1,mid);
113     build(mid+1,r,mid);
114     pre[now]=last;
115     pushup(mid);
116     if(mid<f) ch[last][0]=now;
117     else ch[last][1]=now;
118 }
119 
120 int main()
121 {
122     scanf("%d%d",&n,&m);
123     for(int i=1;i<=n+2;i++)
124         data[i]=++sz;
125     build(1,n+2,0);//建树,建两个哨兵节点为1,n+2。
126     rt=(n+3)>>1;//中点为rt
127     for(int i=1;i<=m;i++){
128         scanf("%d%d",&l,&r);
129         change(l,r);
130     }
131     for(int i=2;i<=n+1;i++)
132         printf("%d ",find(rt,i)-1);//去掉哨兵节点
133     return 0;
134 }

 

 

 

先贴个板子,有的操作并不理解,过几天再看。

 

转载于:https://www.cnblogs.com/ZERO-/p/9610440.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/352852.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

在Spring中了解事务注释

1.简介 Spring为程序性和声明性事务提供支持。 1.1程序化交易 对于程序性事务&#xff0c;需要显式编写事务管理代码&#xff0c;以便在一切成功后提交&#xff0c;并在出现问题时回滚。 在这种情况下&#xff0c;事务管理代码与业务逻辑紧密绑定。 1.2声明式交易 声明式事…

GIS开源库shapeLib的使用方法

转自&#xff1a;http://www.cnblogs.com/liongis/archive/2012/10/23/2736015.html 近期研究了一下GIS开源库shapeLib读写ArcGIS数据的API函数&#xff0c;先整理一下&#xff0c;将各个API的用法介绍一下。 分为两个模块&#xff0c;shape API和DBF API&#xff0c;前者的读取…

linux 升级 iphone,Linux 5.13 更新有望增加对苹果 M1 处理器的支持

IT之家 4 月 10 日消息 预计 Linux 5.13 将初步支持苹果 Silicon M1 处理器&#xff0c;不过可能还需要几年时间才能完全支持。虽然已经在苹果 Silicon M1 上运行&#xff0c;但这是通过一系列的补丁&#xff0c;单纯是为了 Linux 能够在 M1 设备上启动而已&#xff0c;而现在 …

201771010118马昕璐

第一部分 理论知识的学习 第三章Java基本程序设计结构 1 基本知识&#xff1a; &#xff08;1&#xff09;标识符&#xff1a;标识符由字母、下划线、美元符号和数字组成&#xff0c;且第一个符号不能为数字。Hello、$1234、程序名、www_123都是合法标识符。 标识符可用作类名…

Xshell显示中文乱码问题

转载自&#xff1a;http://www.blogjava.net/RoyPayne/archive/2011/12/21/366899.htmlXshell对于嵌入式开发来说&#xff0c;是个非常不错的工具。但或许都有过被中文显示为乱码的问题感觉有点不爽。解决方法其实很简单的&#xff0c;即把xshell编码方式改成UTF-8即可。 [文…

apache wicket_Apache Wicket:记住我的功能

apache wicket在Web应用程序中&#xff0c;很常见的是具有“记住我”功能&#xff0c;该功能使用户每次访问我们的网站时都能自动登录。 可以使用Spring Security来实现这种功能&#xff0c;但我认为将基于请求的身份验证框架与基于组件的Web框架一起使用并不是最好的主意。 这…

linux pap认证,配置PPP PAP 认证

配置PPP PAP 认证&#xff1a;1. 单向认证&#xff1a;R1启动pap R1为主验证方&#xff0c;R2为被验证方。r1(config)#inter s1/0r1(config-if)#ip add 202.146.0.1 255.255.255.0r1(config-if)#no shutdownr1(config-if)#encapsulation pppr1(config-if)#ppp authenticatin pa…

Shell编程关于Sha-Bang(#!)

转载自&#xff1a;http://blog.chinaunix.net/uid-26657936-id-3066136.html Q. #!的名字为什么叫Sha-Bang&#xff1f; A. Sha-Bang是Sharp和Bang的组合词。Sharp for #, Bang for ! 类似的情况是&#xff0c;C#通常被称为C SharpQ. Sha-Bang(#!)是不是注释&#xff1f;A. 不…

您应该保持联系的十大高级Java对话

在线讲座和视频是学习软件开发新事物的主要资源之一。 您可以找到Java专家与您分享他们的经验&#xff0c;而不必坐下来。 在下面的文章中&#xff0c;我们收集了10位我们最喜欢的演讲者和主题&#xff0c;我们相信每个Java开发人员都应该注意。 获取爆米花&#xff0c;坐下来…

c语言定时器作用,Go语言定时器实现原理及作用

对于任何一个正在运行的应用&#xff0c;如何获取准确的绝对时间都非常重要&#xff0c;但是在一个分布式系统中我们很难保证各个节点上绝对时间的一致性&#xff0c;哪怕通过 NTP 这种标准的对时协议也只能把时间的误差控制在毫秒级&#xff0c;所以相对时间在一个分布式系统中…

非常详细的/etc/passwd解释

root:x:0:0:root:/root:/bin/bash bin:x:1:1:bin:/bin:/sbin/nologin daemon:x:2:2:daemon:/sbin:/sbin/nologin desktop:x:80:80:desktop:/var/lib/menu/kde:/sbin/nologin mengqc:x:500:500:mengqc:/home/mengqc:/bin/bash 在该文件中&#xff0c;每一行用户记录的各个数据段…

QT:基本知识(一);

注&#xff1a; 该博文为扩展型&#xff1b; 1) QString转换为LPCTSTR QString szStr; LPCTSTR str (LPWSTR)(szStr.utf16()); 2) 中文乱码解决&#xff1b; QTextCodec *pCodec QTextCode::codecForName("gb2312"); if(!pCodec) return ""; std…

c语言程序设计实训教材,C语言程序设计实训指导书

摘要&#xff1a;李建中等编著的这本《C语言程序设计实训指导书》为《C语言程序设计》的配套教材.全书共分4部分.第1部分主要介绍Visual C6.0的集成功能界面和操作;第2部分配合主教材的内容,设计了11个实验项目;第3部分对主教材每一章习题给出解答或指导;第4部分为全国计算机等…

SUID SGID

转载自&#xff1a;http://www.cnblogs.com/perseus/articles/2830397.html 如果你对SUID、SGID仍有迷惑可以好好参考一下&#xff01; Copyright by kevintz.由于用户在UNIX下经常会遇到SUID、SGID的概念&#xff0c;而且SUID和SGID涉及到系统安全&#xff0c;所以用户也比较…

动态规划:LIS优化

对于1D/1D动态规划来说&#xff0c;理论时间复杂度都是O&#xff08;n^2&#xff09;的&#xff0c;这种动态规划一般都可以进行优化&#xff0c;贴一篇文章 https://wenku.baidu.com/view/e317b1020740be1e650e9a12.html 这里介绍最简单的一种&#xff0c;LIS的求法 其实就是二…

maven 版本号插件_Maven内部版本号插件–用法示例

maven 版本号插件假设我们需要向一些工件&#xff08;jar&#xff0c;war等&#xff09;添加内部版本号。 在这里&#xff0c;我想演示buildnumber-maven-plugin的用法。 这篇文章基于&#xff1a; http://mojo.codehaus.org/buildnumber-maven-plugin/usage.html http://www…

c语言程序设计课件第二章,c语言程序设计课件张元国 ISBN9787566300386 PPT第二章数据类型 运算符与表达式...

1、第2章 数据类型、运算符与表达式,语言的数据类型 常量与变量 运算符与表达式 不同类型数据间的转换,2.1语言的数据类型,数据是计算机程序处理的所有信息的总称&#xff0c;数值、字符、文本等都是数据&#xff0c;在各种程序设计中几乎都要使用和处理数据&#xff0c;程序设…

nowcoder172C 保护 (倍增lca+dfs序+主席树)

https://www.nowcoder.com/acm/contest/172/C &#xff08;sbw大佬太强啦 orz&#xff09; 先把每一个路径(x,y)分成(x,lca),(y,lca)两个路径&#xff0c;然后就能发现&#xff0c;对于某两个&#xff08;直上直下的&#xff09;路径a,b&#xff0c;b的下端点在a的下端点子树中…

添用户报错:useradd:警告:此主目录已经存在

转载自&#xff1a;http://blog.csdn.net/lele892207980/article/details/17239347 建立mysql用户、组 groupadd mysql useradd -g mysql mysql 然后删除 userdel mysql 再添用户和组加时&#xff0c;提示&#xff1a; useradd&#xff1a;警告&#xff1a;此主目录已经存在。…

专业本的C语言,以解决本专业问题为导向的C语言程序设计课程教学探索

以解决本专业问题为导向的C语言程序设计课程教学探索发布时间:2019-08-07 来源: 摘 要 针对C语言程序设计课程在计算机及其相关专业中存在的“狭义工具论”的教学现状&#xff0c;本着“以应用能力培养为目标、以计算思维为手段”的原则进行知识选取和教学内容、教学案例、教学…