BZOJ1269——[AHOI2006]文本编辑器editor
1、题意:各种splay操作,一道好的模板题2333
2、分析:splay模板题,没啥解释QAQ
#include <stack>
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <algorithm>
using namespace std;
#define M 2000010
inline int read(){
char ch = getchar(); int x = 0, f = 1;
while(ch < '0' || ch > '9'){
if(ch == '-') f = -1;
ch = getchar();
}
while('0' <= ch && ch <= '9'){
x = x * 10 + ch - '0';
ch = getchar();
}
return x * f;
}
namespace splay{
struct Node{
Node *ch[2], *fa;
char c;
bool rev;
int size;
inline int which();
inline void reverse(){
rev ^= 1;
swap(ch[0], ch[1]);
}
inline void pd(){
if(rev){
ch[0] -> reverse();
ch[1] -> reverse();
rev = false;
}
}
inline void maintain(){
size = 1 + ch[0] -> size + ch[1] -> size;
}
Node();
} *null = new Node, ft[M];
int tot;
Node::Node(){
size = 1;
c = '\0';
ch[0] = ch[1] = fa = null;
rev = false;
}
inline int Node::which(){
if(fa == null) return -1;
return this == fa -> ch[1];
}
inline void rotate(Node *o){
Node *p = o -> fa;
int l = o -> which(), r = l ^ 1;
o -> fa = p -> fa;
if(p -> which() != -1) p -> fa -> ch[p -> which()] = o;
p -> ch[l] = o -> ch[r];
if(o -> ch[r]) o -> ch[r] -> fa = p;
o -> ch[r] = p; p -> fa = o;
o -> ch[r] -> maintain();
o -> maintain();
}
inline void splay(Node *o){
static stack<Node*> st;
if(!o) return;
Node *p = o;
while(1){
st.push(p);
if(p -> which() == -1) break;
p = p -> fa;
}
while(!st.empty()){
st.top() -> pd();
st.pop();
}
while(o -> which() != -1){
p = o -> fa;
if(p -> which() != -1){
if(p -> which() ^ o -> which()) rotate(o);
else rotate(p);
}
rotate(o);
}
}
inline Node* Kth(Node *o, int k){
o -> pd();
int t = o -> ch[0] -> size + 1;
if(k == t) return o;
if(k < t) return Kth(o -> ch[0], k);
return Kth(o -> ch[1], k - t);
}
inline Node *merge(Node *a, Node *b){
if(a == null) return b;
if(b == null) return a;
Node *p = Kth(a, a -> size);
splay(p);
Node *c = p;
c -> ch[1] = b;
b -> fa = c;
c -> maintain();
return c;
}
inline void split(Node *o, int k, Node* &a, Node* &b){
if(k == 0){
a = null;
b = o;
return;
}
if(k == o -> size){
a = o;
b = null;
return;
}
Node *p = Kth(o, k);
splay(p);
o = p;
o -> maintain();
b = p -> ch[1];
b -> fa = null;
p -> ch[1] = null;
a = p;
a -> maintain();
}
}
using namespace splay;
int main(){
null -> ch[0] = null -> ch[1] = null -> fa = null;
null -> c = '\0'; null -> rev = false; null -> size = 0;
int n = read(); int now = 0;
Node *root = null;
char str[10];
for(int i = 1; i <= n; i ++){
scanf("%s", str);
if(str[0] == 'M'){
int x = read(); now = x;
}
else if(str[0] == 'I'){
int x = read();
Node *a, *b, *d = null;
split(root, now, a, b);
for(int i = 1; i <= x; i ++){
char ch = getchar();
Node *c = &ft[++ tot];
c -> c = ch;
d = merge(d, c);
}
root = merge(a, d);
root = merge(root, b);
}
else if(str[0] == 'D'){
int x = read();
Node *a, *b, *c;
split(root, now, a, b);
split(b, x, b, c);
root = merge(a, c);
}
else if(str[0] == 'R'){
int x = read();
Node *a, *b, *c;
split(root, now, a, b);
split(b, x, b, c);
b -> reverse();
root = merge(a, b);
root = merge(root, c);
}
else if(str[0] == 'G'){
Node *p = Kth(root, now + 1);
printf("%c\n", p -> c);
}
else if(str[0] == 'P'){
now --;
}
else{
now ++;
}
}
return 0;
}
BZOJ1269——[AHOI2006]文本编辑器editor的更多相关文章
- BZOJ1269 [AHOI2006]文本编辑器editor 【82行splay】
1269: [AHOI2006]文本编辑器editor Time Limit: 10 Sec Memory Limit: 162 MB Submit: 4633 Solved: 1782 [Sub ...
- [bzoj1269][AHOI2006文本编辑器editor] (splay模版题 or pb_ds [rope]大法)
Description 这些日子,可可不和卡卡一起玩了,原来可可正废寝忘食的想做一个简单而高效的文本编辑器.你能帮助他吗?为了明确任务目标,可可对“文本编辑器”做了一个抽象的定义: 文本:由0个或 ...
- Bzoj1269 [AHOI2006]文本编辑器editor
Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 3678 Solved: 1380 Description 这些日子,可可不和卡卡一起玩了,原来可可正 ...
- [BZOJ1269] [AHOI2006] 文本编辑器editor (splay)
Description 这些日子,可可不和卡卡一起玩了,原来可可正废寝忘食的想做一个简单而高效的文本编辑器.你能帮助他吗?为了明确任务目标,可可对“文本编辑器”做了一个抽象的定义: 文本:由0个或多 ...
- 【rope】bzoj1269 [AHOI2006]文本编辑器editor
维护一个字符串,支持以下操作: 主要就是 成段插入.成段删除.成段翻转.前两个操作很好通过rope实现.第三个操作也不难,维护两个rope,一个正向,一个反向,翻转时swap一下就行了. ro ...
- 【BZOJ1269/1507】[AHOI2006]文本编辑器editor Splay
[BZOJ1269][AHOI2006]文本编辑器editor Description 这些日子,可可不和卡卡一起玩了,原来可可正废寝忘食的想做一个简单而高效的文本编辑器.你能帮助他吗?为了明确任务目 ...
- 【bzoj1507】[NOI2003]Editor /【bzoj1269】[AHOI2006]文本编辑器editor Splay
[bzoj1507][NOI2003]Editor 题目描述 输入 输入文件editor.in的第一行是指令条数t,以下是需要执行的t个操作.其中: 为了使输入文件便于阅读,Insert操作的字符串中 ...
- AHOI2006文本编辑器editor
1269: [AHOI2006]文本编辑器editor Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 1885 Solved: 683[Submit ...
- BZOJ 1269: [AHOI2006]文本编辑器editor( splay )
splay..( BZOJ 1507 题目基本相同..双倍经验 ) ------------------------------------------------------------------ ...
随机推荐
- UOJ #58 【WC2013】 糖果公园
题目链接:糖果公园 听说这是一道树上莫队的入门题,于是我就去写了--顺便复习了一下莫队的各种姿势. 首先,我们要在树上使用莫队,那么就需要像序列一样给树分块.这个分块的过程就是王室联邦这道题(vfle ...
- [LeetCode] Valid Number 验证数字
Validate if a given string is numeric. Some examples:"0" => true" 0.1 " => ...
- [LeetCode] 3Sum Closest 最近三数之和
Given an array S of n integers, find three integers in S such that the sum is closest to a given num ...
- C#进阶系列——WebApi 身份认证解决方案:Basic基础认证
前言:最近,讨论到数据库安全的问题,于是就引出了WebApi服务没有加任何验证的问题.也就是说,任何人只要知道了接口的url,都能够模拟http请求去访问我们的服务接口,从而去增删改查数据库,这后果想 ...
- 神奇的BFC以及被忽略的东西
BFC是CSS中一个非常重要的概念,经常用来清除浮动以及处理外边距折叠,但BFC到底是个什么东西却很难准确的表达清楚,国内的相关技术文档基本都不全面,本文的目的就是对BFC的方方面面做个整理,当然未必 ...
- FFmpeg 转码和截屏
转码 (flv转码为MP4,libx264是MP4编码格式 , -b 3000k是码率,比特率) ffmpeg -i /home/ghr/mp4/mp4.flv -vcodec libx264 -b ...
- JavaEE学习文章汇总-并发,集群,分布式
以下文章来自博客 http://blog.csdn.net/FX_SKY/article/category/6203839 其中包括 集群Zookeeper 环境搭建 http://blog.csdn ...
- Spring缓存机制的理解
在spring缓存机制中,包括了两个方面的缓存操作:1.缓存某个方法返回的结果:2.在某个方法执行前或后清空缓存. 下面写两个类来模拟Spring的缓存机制: package com.sin90lzc ...
- jquery-三级联动
html <!DOCTYPE html> <html> <head> <meta charset=gbk /> <title>selectL ...
- 封装js的部分兼容性
//获取标签的内容(兼容所有浏览器)function getInnerText(element) { //能力检测(先判断如果这个能力有这个) if(typeof element.innerText ...