【题解】Editor [HDU4699]
【题解】Editor [HDU4699]
【题目描述】
有一个维护整数序列的强大编辑器,初始状态为空,下面提供五种不同的操作,给出的总操作次数 \(m \leqslant 1e6\) 。
\(“I,x”:\) 在光标后面添加一个整数 \(x\);
\(“D”:\) 删除光标前面的整数; \([Backspace]\)
\(“L”:\) 光标向左移动一个单位,除非它已在第一个位置; \([←]\)
\(“R”:\) 光标向右移动一个单位,除非它已在最后一个位置; \([→]\)
\(“Q,k”:\) 输出位置在k之前的最大前缀和。
【样例】
输入:
8
I 2
I -1
I 1
Q 3
L
D
R
Q 2
输出:
2
3
【数据范围】
\(1 \leqslant Q \leqslant 1e6\) \(,\) \(\left| x \right| \leqslant 1000\)
【分析】
对顶栈的炒鸡大水题
但毕竟当初花了那么对时间去搞栈,所以还是水写几篇题解吧...
仔细观察一下题目,问题的关键就在于\(“I”\),\(“D”\),即添加和删除,这里我们先换个词,插入(~~啊恩~)和弹出。如果暂时不考虑光标左右移动的情况,那么每次删除的一定是最后一次插入的整数。后进先出,一进一出的动作都在序列尾进行,这不就是个栈么?
那么如何解决光标左右移动的情况呢?
我们可以设置两个栈 \(L\) 和 \(R\),分别表示光标左右两边的所有数字,靠近光标左右两边的数为栈顶,序列首和序列尾为栈底。
对于每一次的操作:
插入\((“I,x”):\)把 \(x\) 丢进 \(L\)。
删除\((“D”):\)弹出 \(L\) 栈顶元素。
左移\((“L”):\)弹出 \(L\) 栈顶元素,并丢进 \(R\)。
右移\((“R”):\)弹出 \(R\) 栈顶元素,并丢进 \(L\)。
模拟一下。。。
当前的状态:

删除操作后的状态:

右移操作后的状态:

左移操作后的状态:

\((“Q,k”)\) 如何查询最大前缀和?
其实很简单,用一个变量 \(sum\) 表示当前位置的前缀和,再开一个数组 \(f[\) \(]\) 保存每个位置前面的最大前缀和。
当 \(L\) 中有元素 \(x\) 插入时,更新 \(sum\) 和 \(f[\) \(]\),当有元素弹出时,只更新 \(sum\) 。
这道题有两种实现方法:\(STL\) 和手写栈。
不过呢,用 \(STL\) 速度慢,代码长......懂我什么意思了吧....
【Code】
【STL】
#include<iostream>
#include<cstdio>
#include<stack>
using namespace std;
const int N=1e6+5;
stack<int> L,R;
int m,x,t,f[N],sum;char a;
inline int Max(int x,int y){return x>y?x:y;}
int main(){
while(scanf("%d",&m)>0){
t=sum=0;//用t表示当前L中的元素个数,同时也是光标左边的位置
while(!L.empty())L.pop();//清空两个栈
while(!R.empty())R.pop();//QAQ,QWQ,QAQ
f[0]=-0x7fffffff;//这个很重要,否则会WA一片
while(m--){
cin>>a;
if(a=='I'){//添加
scanf("%d",&x);
L.push(x);++t;//左边新增一个数x
f[t]=Max(f[t-1],sum+=x);//更新sum,f[tL]
}
else if(a=='D'&&!L.empty())sum-=L.top(),L.pop(),t--;//删除,sum也实时更新
else if(a=='L'&&!L.empty()){//左移
R.push(L.top());//左边减少一个数,放入右边
sum-=L.top();//更新sum
L.pop();t--;
}
else if(a=='R'&&!R.empty()){//右移
L.push(R.top());t++;//右边减少一个数,放入左边
f[t]=Max(f[t-1],sum+=R.top());//更新sum,f[tL]
R.pop();
}
else if(a=='Q')scanf("%d",&x),printf("%d\n",f[x]);//查询
}
}
}
【手写栈】
#include<iostream>
#include<cstdio>
using namespace std;
const int N=1e6+5;
int m,x,tL,tR,L[N],R[N],f[N],sum;char a;
inline int Max(int x,int y){return x>y?x:y;}
int main(){
while(scanf("%d",&m)>0){
tL=tR=sum=0;f[0]=-0x7fffffff;
while(m--){
cin>>a;
if(a=='I'){
scanf("%d",&x);
L[++tL]=x;
f[tL]=Max(f[tL-1],sum+=x);
}
if(a=='R'&&tR){
x=L[++tL]=R[tR--];
f[tL]=Max(f[tL-1],sum+=x);
}
if(a=='Q')scanf("%d",&x),printf("%d\n",f[x]);
if(a=='L'&&tL){sum-=L[tL],R[++tR]=L[tL--];}
if(a=='D'&&tL)sum-=L[tL--];
}
}
}
【题解】Editor [HDU4699]的更多相关文章
- hdu4699 Editor 2013 多校训练第十场 D题 数列维护 splay | 线段树 | 栈!!!!!
题意:维护一个文本编辑,并且查询最大前缀和. 写了splay,wa了13次 过了之后觉着特傻逼.发现题解两个栈就可以了,光标前后维护两个栈,维护前面的栈的前缀和 和 最大前缀和. 哎,傻逼,太弱了,还 ...
- PC/UVa 题号: 110105/10267 Graphical Editor (图形化编辑器)题解
#include<cstdio> #include<iostream> #include<string> #include<algorithm> #in ...
- HDU-4699 Editor 数据结构维护
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4699 题意:开始有一个光标,每次有5中操作:1,光标当前位置插入一个数,2,光标当前位置删除一个,3, ...
- hdu4699 Editor(双向链表或双栈对弹)
本题就是两个要点: 1.数据结构的设计.显然可以使用双向链表来做,但是写双向链表的代码复杂度高.其实更好的方法是使用两个对弹的栈来做,而且没必要用STL的栈,就自己开两个数组简单搞一下就好了. 2.最 ...
- HDU4699:Editor
浅谈栈:https://www.cnblogs.com/AKMer/p/10278222.html 题目传送门:http://acm.hdu.edu.cn/showproblem.php?pid=46 ...
- AHOI2006文本编辑器editor
1269: [AHOI2006]文本编辑器editor Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 1885 Solved: 683[Submit ...
- NOI2003 文本编辑器editor
1507: [NOI2003]Editor Time Limit: 5 Sec Memory Limit: 162 MBSubmit: 1908 Solved: 738[Submit][Statu ...
- Codeforces Round #350 (Div. 2) E. Correct Bracket Sequence Editor 栈 链表
E. Correct Bracket Sequence Editor 题目连接: http://www.codeforces.com/contest/670/problem/E Description ...
- 【BZOJ1269/1507】[AHOI2006]文本编辑器editor Splay
[BZOJ1269][AHOI2006]文本编辑器editor Description 这些日子,可可不和卡卡一起玩了,原来可可正废寝忘食的想做一个简单而高效的文本编辑器.你能帮助他吗?为了明确任务目 ...
随机推荐
- 算法-memcopy与memmove的区别
memcpy()和 memmove()都是C语言中的库函数,在头文件string.h中,作用是拷贝一定长度的内存的内容,原型如下 void *memcpy(void *dst, const void ...
- MySQL Error--InnoDB Table mysqlinnodb_index_stats has length mismatch in the column
使用MySQL 5.7.24版本的安装文件替换MySQL 5.7.19版本的安装文件,数据库复制频繁中断,查看error日志发现下面错误: [Warning] InnoDB: Table mysql/ ...
- 在eclipse中使用Maven分模块搭建SSM框架,创建jar、war、pom工程模块教学,项目的热部署,需要的可以留下邮箱,给大家发整理过的Maven笔记
第一章:Maven概述 (1)Maven是一个项目构建工具,由apache提供,用Java开发的 (2)构建工具:Ant(蚂蚁),Maven(专家) (3)构建工具作用:帮助程序员进行项目的创建,目录 ...
- Odoo中的字段显示方式和行为控制
在odoo的视图中,字段都是通过widget来控制显示效果和行为的. 一般情况下,不同类型的字段odoo会使用默认的widget来显示和控制它的行为. options以一种JSON对象的形 ...
- <h1>~<h6> 标题标签
<h1>~</h6>标题系列标签 解释:h1到h6 中h1标签最大,h6标签最小,逐一递增. 例如: <h1>标签</h1> <h2>标签& ...
- 大数据技术原理与应用【第五讲】NoSQL数据库:5.5 从NoSQL到NewSQL数据库
应用场景: OldSql数据库:希望一种架构就能支持多种应用场景,但证明不可能. NewSql数据库:同时具备OldSql和NoSQL各自的优点:水平可扩展性,强一致性,事务一致性,支持查询,支持 ...
- K8s Helm安装配置入门
作为k8s现在主流的一种包部署方式,尽管不用,也需要进行一些了解.因为,它确实太流行了. 这一套太极拳打下来,感觉helm这种部署,目前还不太适合于我们公司的应用场景.它更适合需要手工编程各种yaml ...
- WooCommerce代码合集整理
本文整理了一些WooCommerce代码合集,方便查阅和使用,更是为了理清思路,提高自己.以下WooCommerce简称WC,代码放在主题的functions.php中即可. 修改首页和分类页面每页产 ...
- JAVA web 框架集合
“框架”犹如滔滔江水连绵不绝, 知道有它就好,先掌握自己工作和主流的框架: 在研究好用和新框架. 主流框架教程分享在Java帮帮-免费资源网 其他教程需要时间制作,会陆续分享!!! 152款框架,你还 ...
- 通过ALTER DATABASE postgres SET 解决 plv8 plv8.start_proc 问题
通过plv8.start_proc 我们可以使用类似钩子的改变 ,方便的扩展plv8,比如基于plv8.start_proc 的require 实现 命令 ALTER DATABASE postgre ...