博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
11988 - Broken Keyboard (a.k.a. Beiju Text)
阅读量:4129 次
发布时间:2019-05-25

本文共 1053 字,大约阅读时间需要 3 分钟。

题目链接:http://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem&problem=3139

题目大意:给定一个字符串,内部含有”【“和”】“光标转移指令,

【代表光标移向文章头,】代表光标移向文章尾,问最终在屏幕上显示的字符串序列是?

解题题报告人:GHQ(SpringWater)

解题思路:考虑到后面的【比总会前面的【使得,字符更加靠前,所以我就从右边考试需找【,找到就输出,

左边的】在序列里没起作用,所以不用管,遇到直接输出!看起来很简单,但是他这题最恶心的是,你不能将最终的

结果strcat到一个ans数组里,否则会超时,所以你只有直接输出!但这里还要注意的是,当你从左到右查找】之前,

必须判定开头是否已字母开头,单独处理一下就是了!

#include
#include
#define MAXN 100002char s[MAXN],temp[MAXN];int main(){ int i,len; while(~scanf("%s",s)) { len=strlen(s); for(i = 0; i < len; ++i) { if(s[i]=='['||s[i]==']') temp[i] = '\0'; else temp[i] = s[i]; } temp[len]='\0'; for(i = len - 1; i > -1; --i) { if(s[i]=='[') printf("%s",temp+i+1); } if(!(s[0]=='['||s[0]==']')) printf("%s",temp); for(i = 1; i < len; ++i){ if(s[i]==']') printf("%s",temp+i+1); } printf("\n"); } return 0;}

转载地址:http://ohuvi.baihongyu.com/

你可能感兴趣的文章
自己的网站与UCenter整合(大致流程)
查看>>
laravel 制作通用的curd 后台操作
查看>>
【小红书2017年笔试】求一个数组中平均数最大的子数组
查看>>
Linux基础系列-定时器与时间管理
查看>>
Linux基础系列-可执行程序的产生过程
查看>>
Linux基础系列-Kernel 初始化宏
查看>>
Linux子系统系列-I2C
查看>>
<iOS>关于自定义description的一点用法
查看>>
Unix 命令,常用到的
查看>>
DLL中建立进程共享数据段需要注意的语法问题
查看>>
服务器端技术----Http请求的处理过程
查看>>
C语言-预处理指令2-条件编译
查看>>
C语言-预处理指令3-文件包含
查看>>
C语言-变量类型
查看>>
C语言-static和extern关键字1-对函数的作用
查看>>
C 语言-static和extern关键字2-对变量的作用
查看>>
【JavaScript 教程】浏览器—History 对象
查看>>
还不会正则表达式?看这篇!
查看>>
100道+ JavaScript 面试题,助你查漏补缺
查看>>
JavaScript深入理解之闭包
查看>>