剪切粘贴(pta团体天梯题)c++超简单详细刨析版

2024-03-11 06:52

本文主要是介绍剪切粘贴(pta团体天梯题)c++超简单详细刨析版,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

使用计算机进行文本编辑时常见的功能是剪切功能(快捷键:Ctrl + X)。请实现一个简单的具有剪切和粘贴功能的文本编辑工具。

工具需要完成一系列剪切后粘贴的操作,每次操作分为两步:

  • 剪切:给定需操作的起始位置和结束位置,将当前字符串中起始位置到结束位置部分的字符串放入剪贴板中,并删除当前字符串对应位置的内容。例如,当前字符串为 abcdefg,起始位置为 3,结束位置为 5,则剪贴操作后, 剪贴板内容为 cde,操作后字符串变为 abfg。字符串位置从 1 开始编号。
  • 粘贴:给定插入位置的前后字符串,寻找到插入位置,将剪贴板内容插入到位置中,并清除剪贴板内容。例如,对于上面操作后的结果,给定插入位置前为 bf,插入位置后为 g,则插入后变为 abfcdeg。如找不到应该插入的位置,则直接将插入位置设置为字符串最后,仍然完成插入操作。查找字符串时区分大小写。

每次操作后的字符串即为新的当前字符串。在若干次操作后,请给出最后的编辑结果。

输入格式:

输入第一行是一个长度小于等于 200 的字符串 S,表示原始字符串。字符串只包含所有可见 ASCII 字符,不包含回车与空格。

第二行是一个正整数 N (1≤N≤100),表示要进行的操作次数。

接下来的 N 行,每行是两个数字和两个长度不大于 5 的不包含空格的非空字符串,前两个数字表示需要剪切的位置,后两个字符串表示插入位置前和后的字符串,用一个空格隔开。如果有多个可插入的位置,选择最靠近当前操作字符串开头的一个。

剪切的位置保证总是合法的。

输出格式:

输出一行,表示操作后的字符串。

输入样例:

AcrosstheGreatWall,wecanreacheverycornerintheworld
5
10 18 ery cor
32 40 , we
1 6 tW all
14 18 rnerr eache
1 1 e r

输出样例:

he,allcornetrrwecaneacheveryGreatWintheworldAcross

 刷pta的题目才发现刷一道综合一点的题目真的可以抵好多道那种字符串的问题了,通过理解题目得到大概的思路其实并不难,这题的题目意思就是复制一个字符串的子串然后删除粘贴到某一位置,只是把这个过程重复多次而已

因此我们可以把难点归类一下

1.怎么得到剪切(即删除)后的字符串?

2.怎么找到需要粘贴的位置?这里给了粘贴后前面的字符串和后面的字符串,长度不大于五,可能也是比较难突破的一个点了

3.怎么把字符串粘贴到2找到的位置回去?

这题目其实就是难在这三个点,其实这就是平时刷的一些字符串的问题只是综合在一起考了,这里我们一个点一个点来突破

首先就是难点1,怎么得到剪切后的原字符串,其实化为一个字符串问题就是一个删除子字符串问题,但这毕竟只是一个小点,花太多时间在这里很浪费,因此我们可以直接使用erase函数,即原字符串.erase(开始删除字符的下标,要删除的长度),这个函数可以直接套用得到删除后的字符串,字符串长度也会自动跟着变化,例如

 

其次就是难点二,也是这题最难的一个点,怎么找到要从哪里开始加入剪切的字符串呢?题目给出了加入前后的字符串来让我们找位置,假设找得到的话,那么在粘贴之前题目给出的前后字符串一定是连在一起的我们就可以直接找他们连起来后在原字符串里有没有哪段出现,如果出现了就说明找到了 ,这里可以用第二个函数即find函数,可以直接在原字符串里找到子字符串开始出现的位置,没找到则返回-1,而且也是先找的前面的位置刚好满足题意,函数原型为 字符串.find(子字符串),使用如下图

最后就是难点三的突破了,怎么把找到的字符串粘贴回去,这里就要用到本题的第三个函数了,即insert函数可以直接在某个位置插入字符串并且也是自动改变字符串的长度,哈哈哈哈就是这么爽,可以直接用,函数原型为字符串.insert(要插入的位置,插入的字符串) ,使用样例如下

看到了吗三个难点都有三个函数可以解决还不直接记!!只要知道函数这题就很简单也可以很快地写,与其一个一个去写那么多不如一个函数方便快捷,考场时间把握很重要,不过记得在使用前都要在前面加上头文件#include<string>,下面就直接给出整个一个代码了

代码如下:

#include<iostream>
#include<string>
using namespace std;
string s;
//得到复制的字符串
string fff(int a, int b) {string m;for (int i = a-1; i < b; i++) m += s[i];return m;
}
void zhantie(string a, string b, string c) {string m = b + c;//假如找到了可以插入的位置int t = s.find(m);if (t >= 0) {s.insert(t + b.size(), a);}//假如原字符串没有可以插入的位置,直接插到最后面else {s.insert(s.size(), a);}
}
int main()
{getline(cin, s);int k;cin >> k;while (k--) {int begin, end;string qian, hou;cin >> begin >> end >> qian >> hou;string fuzhi = fff(begin, end);s.erase(begin-1,end-begin+1);//删除原字符串剪切完的字符串zhantie(fuzhi, qian, hou);//得到粘贴后的字符串}cout << s << endl;return 0;
}

后面补充个小细节就是find函数假如没找到,直接使用find(m)会返回一个很大的值,而不是-1,因此这代码用了int t来特意接受find后的值,没找到就会返回-1

这篇关于剪切粘贴(pta团体天梯题)c++超简单详细刨析版的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/796999

相关文章

Python设置Cookie永不超时的详细指南

《Python设置Cookie永不超时的详细指南》Cookie是一种存储在用户浏览器中的小型数据片段,用于记录用户的登录状态、偏好设置等信息,下面小编就来和大家详细讲讲Python如何设置Cookie... 目录一、Cookie的作用与重要性二、Cookie过期的原因三、实现Cookie永不超时的方法(一)

SpringBoot整合liteflow的详细过程

《SpringBoot整合liteflow的详细过程》:本文主要介绍SpringBoot整合liteflow的详细过程,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋...  liteflow 是什么? 能做什么?总之一句话:能帮你规范写代码逻辑 ,编排并解耦业务逻辑,代码

从入门到精通C++11 <chrono> 库特性

《从入门到精通C++11<chrono>库特性》chrono库是C++11中一个非常强大和实用的库,它为时间处理提供了丰富的功能和类型安全的接口,通过本文的介绍,我们了解了chrono库的基本概念... 目录一、引言1.1 为什么需要<chrono>库1.2<chrono>库的基本概念二、时间段(Durat

C++20管道运算符的实现示例

《C++20管道运算符的实现示例》本文简要介绍C++20管道运算符的使用与实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录标准库的管道运算符使用自己实现类似的管道运算符我们不打算介绍太多,因为它实际属于c++20最为重要的

Visual Studio 2022 编译C++20代码的图文步骤

《VisualStudio2022编译C++20代码的图文步骤》在VisualStudio中启用C++20import功能,需设置语言标准为ISOC++20,开启扫描源查找模块依赖及实验性标... 默认创建Visual Studio桌面控制台项目代码包含C++20的import方法。右键项目的属性:

浏览器插件cursor实现自动注册、续杯的详细过程

《浏览器插件cursor实现自动注册、续杯的详细过程》Cursor简易注册助手脚本通过自动化邮箱填写和验证码获取流程,大大简化了Cursor的注册过程,它不仅提高了注册效率,还通过友好的用户界面和详细... 目录前言功能概述使用方法安装脚本使用流程邮箱输入页面验证码页面实战演示技术实现核心功能实现1. 随机

c++中的set容器介绍及操作大全

《c++中的set容器介绍及操作大全》:本文主要介绍c++中的set容器介绍及操作大全,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录​​一、核心特性​​️ ​​二、基本操作​​​​1. 初始化与赋值​​​​2. 增删查操作​​​​3. 遍历方

解析C++11 static_assert及与Boost库的关联从入门到精通

《解析C++11static_assert及与Boost库的关联从入门到精通》static_assert是C++中强大的编译时验证工具,它能够在编译阶段拦截不符合预期的类型或值,增强代码的健壮性,通... 目录一、背景知识:传统断言方法的局限性1.1 assert宏1.2 #error指令1.3 第三方解决

C++11委托构造函数和继承构造函数的实现

《C++11委托构造函数和继承构造函数的实现》C++引入了委托构造函数和继承构造函数这两个重要的特性,本文主要介绍了C++11委托构造函数和继承构造函数的实现,具有一定的参考价值,感兴趣的可以了解一下... 目录引言一、委托构造函数1.1 委托构造函数的定义与作用1.2 委托构造函数的语法1.3 委托构造函

C++11作用域枚举(Scoped Enums)的实现示例

《C++11作用域枚举(ScopedEnums)的实现示例》枚举类型是一种非常实用的工具,C++11标准引入了作用域枚举,也称为强类型枚举,本文主要介绍了C++11作用域枚举(ScopedEnums... 目录一、引言二、传统枚举类型的局限性2.1 命名空间污染2.2 整型提升问题2.3 类型转换问题三、C