POJ C++程序设计 编程题#4 字符串操作
2015-09-03 15:03
2016 查看
编程题#4: 字符串操作
来源: POJ (Coursera声明:在POJ上完成的习题将不会计入Coursera的最后成绩。)注意: 总时间限制: 1000ms 内存限制: 65536kB
描述
给定n个字符串(从1开始编号),每个字符串中的字符位置从0开始编号,长度为1-500,现有如下若干操作:copy N X L:取出第N个字符串第X个字符开始的长度为L的字符串。
add S1 S2:判断S1,S2是否为0-99999之间的整数,若是则将其转化为整数做加法,若不是,则作字符串加法,返回的值为一字符串。
find S N:在第N个字符串中从左开始找寻S字符串,返回其第一次出现的位置,若没有找到,返回字符串的长度。
rfind S N:在第N个字符串中从右开始找寻S字符串,返回其第一次出现的位置,若没有找到,返回字符串的长度。
insert S N X:在第N个字符串的第X个字符位置中插入S字符串。
reset S N:将第N个字符串变为S。
print N:打印输出第N个字符串。
printall:打印输出所有字符串。
over:结束操作。
其中N,X,L可由find与rfind操作表达式构成,S,S1,S2可由copy与add操作表达式构成。
输入
第一行为一个整数n(n在1-20之间)接下来n行为n个字符串,字符串不包含空格及操作命令等。
接下来若干行为一系列操作,直到over结束。
输出
根据操作提示输出对应字符串。样例输入
3 329strjvc Opadfk48 Ifjoqwoqejr insert copy 1 find 2 1 2 2 2 print 2 reset add copy 1 find 3 1 3 copy 2 find 2 2 2 3 print 3 insert a 3 2 printall over
样例输出
Op29adfk48 358 329strjvc Op29adfk48 35a8
提示
推荐使用string类中的相关操作函数。这题很没有思路,参考了这个答案http://bailian.openjudge.cn/topic/3534/
第一次遇到这种题,多做做可能会好多了,第一次做没啥办法
注意将itos函数用sprintf函数替代,反正我电脑上不认itos这个函数
同时要多加入头文件
#include<stdio.h> #include <stdlib.h>
相关文章推荐
- twoSum(C++)
- 【more effective c++读书笔记】【第5章】技术(2)——限制某个class所能产生的对象数量
- 【more effective c++读书笔记】【第5章】技术(2)——限制某个class所能产生的对象数量
- c++STL容器
- C语言访问MCU寄存器的三种方式
- 【模板】c++ template模板实现string到Num的转换
- C++中泛型算法
- C语言实现冒泡排序-整数排序
- 【C/C++学院】0730-网站以及后门/结构体对齐、结构体面试分析/深拷贝与浅拷贝/队列/字符串封装
- C语言链表中数组实现数据选择排序,升序、降序功能主要难点
- C语言链表中数组实现数据选择排序,升序、降序功能主要难点
- C++中构造函数和析构函数的调用顺序
- C++面向对象编程
- C++ 静态成员的类内初始化
- C语言实现链式队列
- C++标准库set类型
- c++ primer读书笔记之c++11(二)
- C语言的日期和时间库
- 如何在Windows7操作系统下安装用于C++开发的Eclipse
- c语言二维数组的定义和初始化