https://vjudge.net/problem/UVA-11988

题目

你有一个破损的键盘。键盘上所有的键都可以正常工作,但有时候Home键或者End键会自动按下。你并不知道键盘存在这一问题,而是专心打稿子,甚至连显示器都没打开。当你打开显示器后,展现在你面前的是一段悲剧文本。你的任务是在打开显示器之前计算出这段悲剧文本。

输入包含多组数据。每组数据占一行,包含不超过100000个字母、下划线、字符“[”或者“]”。其中字符“[”表示Home键,“]”表示End键。输入结束标志为文件结束符(EOF)。输入文件不超过5MB。对于每组数据,输出一行,即屏幕上的悲剧文本。

样例输入:

This_is_a_[Beiju]_text
[[]][][]Happy_Birthday_to_Tsinghua_University

样例输出:

BeijuThis_is_a_text
Happy_Birthday_to_Tsinghua_University

题解

服了= =

两年前看见这题……看不懂

几个月前看了邓公的数据结构课的链表大概知道是怎么回事了……(“邓俊辉的数据结构,贵系授课质量最好的课”)

个人思路:

写个双向链表……在Start后(需要更新cur)或End处插入元素……

如果在start处还需要记录当前的字符位置:

比如已经输入1和2,将要插入3……

可以定义个node结构体,包含last、next和ch三个元素,然后定义个node数组,直接操作就好了……

但是紫书上告诉我可以用单向链表,不用定义结构体……代码量还很小,不用分别是否在讨论Start和End插入

紫书上的答案:

如果使用单向链表,尝试理解了下书上给的答案

如果使用单向,那么End节点作用就不大,不能用End来找出之前的元素,直接定义为-1……在最后插入仍然需要记录当前的位置(如d)

那么在Start和End处的插入操作可以统一

那么大概就懂了……开始编码

#include<bits/stdc++.h>
using namespace std; #define REP(i,x,y) for(register int i=x; i<y; i++)
#define REPE(i,x,y) for(register int i=x; i<=y; i++) char s[100007];
int nxt[100007];
int lst, cur;
int main() {
while(~scanf("%s", s+1)) {
nxt[0]=-1;
cur=0;
for(int i=1; s[i]; i++) {
if(s[i]=='[') {
lst = cur;
cur = 0;
} else if(s[i]==']') {
cur = lst;
} else {
nxt[i]=nxt[cur];
nxt[cur]=i;
cur=i;
}
}
for(int i=nxt[0]; ~i; i=nxt[i]) {
putchar(s[i]);
}
putchar('\n');
}
return 0;
}

然后就WA了……

看到标程,发现Home键可能不止按下一次……有点悲剧

AC代码:

#include<bits/stdc++.h>
using namespace std; #define REP(i,x,y) for(register int i=x; i<y; i++)
#define REPE(i,x,y) for(register int i=x; i<=y; i++) char s[100007];
int nxt[100007];
int lst, cur;
int main() {
while(~scanf("%s", s+1)) {
nxt[0]=-1;
cur=0, lst=0;
for(int i=1; s[i]; i++) {
if(s[i]=='[') {
cur = 0;
} else if(s[i]==']') {
cur = lst;
} else {
nxt[i]=nxt[cur];
nxt[cur]=i;
if(lst==cur) lst=i;
cur=i;
}
}
for(int i=nxt[0]; ~i; i=nxt[i]) {
putchar(s[i]);
}
putchar('\n');
}
return 0;
}

然后感叹: 刘老爷是真的牛批,邓公的数据结构课是真的毛……

UVA 11988 Beiju Text的更多相关文章

  1. 破损的键盘(悲剧文本)(Broken Keyboard(a.k.a. Beiju Text),Uva 11988)

    破损的键盘(悲剧文本)(Broken Keyboard(a.k.a. Beiju Text),Uva 11988) 题意描述 你在输入文章的时候,键盘上的Home键和End键出了问题,会不定时的按下. ...

  2. UVA 11988 Broken Keyboard (a.k.a. Beiju Text)(链表)

    题目代号:UVA 11988 题目链接:https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&pa ...

  3. UVA——11988 Broken Keyboard (a.k.a. Beiju Text)

    11988 Broken Keyboard (a.k.a. Beiju Text)You’re typing a long text with a broken keyboard. Well it’s ...

  4. UVa 11988 Broken Keyboard (a.k.a. Beiju Text)(链表)

    You're typing a long text with a broken keyboard. Well it's not so badly broken. The only problem wi ...

  5. Broken Keyboard (a.k.a. Beiju Text) UVA - 11988

    You're typing a long text with a broken keyboard. Well it's not so badly broken. The only problem wi ...

  6. uva - Broken Keyboard (a.k.a. Beiju Text)(链表)

    11988 - Broken Keyboard (a.k.a. Beiju Text) You’re typing a long text with a broken keyboard. Well i ...

  7. UVa 11988 Broken Keyboard(链表->数组实现)

    /*数组形式描述链表:链表不一定要用指针. 题目链接:UVa 11988 Broken Keyboard 题目大意: 小明没有开屏幕输入一个字符串,电脑键盘出现了问题会不定时的录入 home end ...

  8. B - Broken Keyboard (a.k.a. Beiju Text)

    Problem B Broken Keyboard (a.k.a. Beiju Text) You're typing a long text with a broken keyboard. Well ...

  9. B - Broken Keyboard (a.k.a. Beiju Text) 数组模拟链表

    You're typing a long text with a broken keyboard. Well it's not so badly broken. The only problem wi ...

随机推荐

  1. Unity热更新学习(一) —— AssetBundle 打包和加载

    理论不多说,网上,官方文档都有.  这里有一篇介绍很全面的文章:https://www.cnblogs.com/ybgame/p/3973177.html 示例和注意点记录一下,用到时以便查阅. 一. ...

  2. IDE安装Lombok插件提高开发效率

    Lombok官方api:https://projectlombok.org/features/index.html 使用lombok之后,省去了许多没必要的get,set,toString,equal ...

  3. 算法相关——Java排序算法之希尔排序(五)

    个子块,即{3,5},{1,0},{5,2},{9,4},{6,12},将每个子块进行插入排序(即第i位与第i+5位进行比较交换),初步排序结果为{3,0,2,4,6,5,1,5,9,12}.希尔排序 ...

  4. mybatis百科-结果集映射类ResultMap

    目录 1 成员变量 2 构造函数 3 其他函数 3.1 setter 和 getter 函数 4 静态内部类 4.1 成员变量 4.2 构造函数 4.3 建造者相关的函数 4.4 获取配置的构造方法参 ...

  5. Jenkins-job之间依赖关系配置

    使用场景: 想要在某APP打新包之后,立即执行自动化测试的job来验证该新包. 比如Job A 执行完执行Job B ,如下图所示,如何建立依赖呢? 1.配置上游依赖 构建触发器-配置如下信息: 选择 ...

  6. 第十二届湖南省赛G - Parenthesis (树状数组维护)

    Bobo has a balanced parenthesis sequence P=p 1 p 2…p n of length n and q questions. The i-th questio ...

  7. 利用tushare进行对兴业银行股价的爬取,并使用numpy进行分析

    import sysimport tushare as tsimport numpy as npdata=ts.get_h_data('601066')print(data)#读出兴业银行7列数据da ...

  8. 砝码组合(dfs)

    砝码组合  题目内容:用天平称重时,我们希望用尽可能少的砝码组合称出尽可能多的重量.如果只有5个砝码,重量分别是1,3,9,27,81.则它们可以组合称出1到121之间任意整数重量(砝码允许放在左右两 ...

  9. 聊一聊跨域,Vue向Django请求数据的一些问题

    1.做前后端分离 前端使用Vue程序,后端使用Django配合rest-framework. 那么前端Vue通过API接口拿到数据会出现跨域的问题,JSONP只是在get中会用到的,所以这里使用cor ...

  10. Html5使用canvas作图

    以下例子是项目中实际用到的.不足之处请大家指正,设计到画线,写文字,填充,文字旋转. <!DOCTYPE html> <html> <head lang="en ...