【字符串】ZSC-字符串编辑
Description
从键盘输入一个字符串(长度<=40个字符),对字符串进行编辑。例如,输入"This is a book." 现对该字符串进行编辑,编辑功能有:(1) D:删除一个字符,命令的方式为: D a 其中a为被删除的字符。若字符串中有多个a,则删除第一次出现的。 例如:D s 表示删除字符 's' ,若字符串中有多个 ‘s’,则删除第一次出现的。 如原串为"This is a book.",删除的结果为:"Thi is a book."(2) I:插入一个字符,命令的格式为: I a1 a2 其中a1表示插入到指定字符前面,a2表示将要插入的字符。若原串中有多个a1,则插入在最后一个字符的前面。 例如:I s d 表示在指定字符 's' 的前面插入字符 'd' ,若原串中有多个's',则插入在最后一个字符的前面。 如原串为:"This is a book.",插入后变成"This ids a book."(3) R:替换一个字符,命令格式为: R a1 a2 其中a1为被替换的字符,a2为替换的字符,若在原串中有多个a1则应全部替换。 例如:R o e表示将所有字符o替换成e. 如原串为"This is a book.",替换后的字符串为:"This is a beek."在编辑过程中,若编辑后的字符串跟编辑前的字符串相同的话,则给出提示信息"Not Changed!"。
Input
输入数据包括多行。第一行一个字符串(长度<=40),表示原串。第二行是一个正整数n,表示接下来有n条编辑指令。接下来有n行,每行一条指令,格式如上述三种格式之一。数据保证所有指令格式都正确,且修改后的字符串长度不会超过100.
Output
输出有n行。第i行表示执行第i条指令后得到的字符串,或提示信息"Not Changed!"
Sample Input
This is a book.
5
D s
I o r
R s t
R q p
I o d
Sample Output
Thi is a book.
Thi is a borok.
Thi it a borok.
Not Changed!
Thi it a bordok.
#include <iostream>
#include <string>
#include <cstring> //题库strlen函数的需要
#include <string.h> //题库strlen函数的需要
using namespace std;
void Delete(char str[],char e,int &len,int &pd);
void Insert(char str[],char e,char r,int &len,int &pd);
void Replace(char str[],char e,char r,int &len,int &pd);
int main()
{
char str[102];
cin.getline(str,102);
int len=strlen(str);
int n;
cin>>n;
while(n--)
{
int pd=0;
char j;
cin>>j;
if(j=='D')
{
char e;
cin>>e;
Delete(str,e,len,pd);
}else if(j=='I')
{
char e,r;
cin>>e>>r;
Insert(str,e,r,len,pd);
}else if(j=='R')
{
char e,r;
cin>>e>>r;
Replace(str,e,r,len,pd);
}
if(pd==1)
{
for(int i=0;i<len;i++) cout<<str[i];
cout<<endl;
}
else
cout<<"Not Changed!"<<endl;
}
return 0;
}
void Delete(char str[],char e,int &len,int &pd)
{
for(int i=0;i<strlen(str);i++)
{
if(str[i]==e)
{
for(int j=i;j<strlen(str)-1;j++) //往前补
{
str[j]=str[j+1];
}
len--; //长度-1
pd=1; //将修改进行记录
break; //一次就跳出
}
}
}
void Insert(char str[],char e,char r,int &len,int &pd)
{
for(int i=len-1;i>=0;i--)
{
if(str[i]==e)
{
for(int j=len-1;j>=i;j--) //向后移
{
str[j+1]=str[j];
}
str[i]=r; //插入字符
pd=1; //将修改进行记录
len++; //长度+1
break;
}
}
}
void Replace(char str[],char e,char r,int &len,int &pd)
{
if(e==r) return; //替换符和被替换符相同时直接跳出
for(int i=0;i<len;i++)
{
if(str[i]==e) //替换所有字符,所以没有break
{
str[i]=r;
pd=1; //将修改进行记录
}
}
}
【字符串】ZSC-字符串编辑的更多相关文章
- c#.net常用字符串函数 字符串常用方法
RegionsStr = RegionsStr.Remove(RegionsStr.LastIndexOf(","), 1); //去掉最后一个逗号 Compare 比较字符串 ...
- c#.net常用字符串函数 字符串常用方法 string
RegionsStr = RegionsStr.Remove(RegionsStr.LastIndexOf(","), 1); //去掉最后一个逗号 string html = ...
- JS字符串替换函数:Replace(“字符串1″, “字符串2″),
JS字符串替换函数:Replace(“字符串1″, “字符串2″), 1.我们都知道JS中字符串替换函数是Replace(“字符串1″, “字符串2″),但是这个函数只能将第一次出现的字符串1替换掉, ...
- Javascript里,想把一个整数转换成字符串,字符串长度为2
Javascript里,想把一个整数转换成字符串,字符串长度为2. 想把一个整数转换成字符串,字符串长度为2,怎么弄?比如 1 => "01"11 => " ...
- 第一百二十七节,JavaScript,JSON数据类型转换,数据转换成字符串,字符串转换成数据
第一百二十七节,JavaScript,JSON数据类型转换,数据转换成字符串,字符串转换成数据 学习要点: 1.JSON语法 2.解析和序列化 前两章我们探讨了XML的结构化数据,但开发人员还是觉得这 ...
- [ACdream]女神教你字符串——导字符串
Problem Description 正如大家知道的,女神喜欢字符串,而在字符串中,女神最喜欢回文字符串,但是不是所有的字符串都是回文字符串,但是有一些字符串可以进行“求导”来变成回文字符串. 字符 ...
- go golang 判断base64数据 获取随机字符串 截取字符串
go golang 判断base64数据 获取随机字符串 截取字符串 先少写点,占个坑,以后接着加. 1,获取指定长度随机字符串 func RandomDigits(length int) strin ...
- jquery获取当前按钮、截取字符串、字符串拼接、动态循环添加元素
截取字符串:字符串拼接:动态循环添加元素:获取当前按钮: {data : null, render: function(data, type, row ) { var loginName = $(&q ...
- 剑指offer 1,输入一个字符串,将字符串的空格替换成%20
剑指offer 1,输入一个字符串,将字符串的空格替换成%20 function replaceSpace(str){ return str.replace(/\s/g,"% ...
- C++二进制字符串转Base64字符串 Base64字符串转二进制字符串
封装成类的 . base64格式的字符串,只包含大小写字母.零到九,以及 + / //___base_64.h /*base_64.h文件*/ #ifndef BASE_64_H #define BA ...
随机推荐
- 业务开发(六)—— MyBatis框架
0x01.元素内容必须由格式正确的字符数据或标记组成. Caused by: org.apache.ibatis.builder.BuilderException: Error creating do ...
- 一个小时学会Maven
一.为什么要Maven 在开发中经常需要依赖第三方的包,包与包之间存在依赖关系,版本间还有兼容性问题,有时还里要将旧的包升级或降级,当项目复杂到一定程度时包管理变得非常重要. Maven是当前最受欢迎 ...
- [android] 短信的广播接收者
比较重要的一个广播事件,短信 界面布局,比如播放视频,默认是横屏全屏的,清单文件中进行设置, 在<activity/>节点设置屏幕朝向属性,android:screenOrientatio ...
- Android Material Design控件使用(二)——FloatButton TextInputEditText TextInputLayout 按钮和输入框
FloatingActionButton 1. 使用FloatingActionButton的情形 FAB代表一个App或一个页面中最主要的操作,如果一个App的每个页面都有FAB,则通常表示该App ...
- 5. CopyOnWriteArrayList 的适用场景
package com.gf.demo04; import java.util.ArrayList; import java.util.Collections; import java.util.It ...
- JDK动态代理简单使用(2)
JDK动态代理使用: 使用JDK动态代理步骤: ①创建被代理的接口和类: public interface IA { void f1(String param); } public class A i ...
- mybatis插件机制
目录 mybatis插件机制 主要 类/接口 和 方法 mybatis插件机制实现 mybatis插件机制 mybatis的插件机制使用动态代理实现,不了解的朋友请先了解代理模式和动态代理:插件本质是 ...
- 新浪微博登陆以及发送微博(附python源码)
原文链接(本人):https://blog.csdn.net/A5878989/article/details/76275855 说明 本文主要记录分析新浪微博登陆以及发送文字和图片微博的详细过程 分 ...
- javascript模块化编程-立即执行函数(IIFE)
IIFE 全拼Imdiately Invoked Function Expression,立即执行的函数表达式. 语法 var module1 = (function(){ var _count = ...
- SAP MM 没有维护MRP 视图的物料可以正常参与采购业务
SAP MM 没有维护MRP 视图的物料可以正常参与采购业务 Material number: R000006872,没有维护MRP 视图, 也就是没有指定该物料来源是采购还是自制.此种情况下,S ...