P5734 【深基6.例6】文字处理软件

题目描述

你需要开发一款文字处理软件。最开始时输入一个字符串作为初始文档。可以认为文档开头是第 00 个字符。需要支持以下操作:

  • 1 str:后接插入,在文档后面插入字符串 strstr,并输出文档的字符串。

  • 2 a b:截取文档部分,只保留文档中从第 �a 个字符起 �b 个字符,并输出文档的字符串。

  • 3 a str:插入片段,在文档中第 �a 个字符前面插入字符串 strstr,并输出文档的字符串。

  • 4 str:查找子串,查找字符串 strstr 在文档中最先的位置并输出;如果找不到输出 −1−1。

为了简化问题,规定初始的文档和每次操作中的 strstr 都不含有空格或换行。最多会有 �q 次操作。

输入格式

第一行输入一个正整数 �q,表示操作次数。

第二行输入一个字符串 strstr,表示最开始的字符串。

第三行开始,往下 �q 行,每行表示一个操作,操作如题目描述所示。

输出格式

一共输出 �n 行。

对于每个操作 1,2,31,2,3,根据操作的要求输出一个字符串。

对于操作 44,根据操作的要求输出一个整数。

输入输出样例

输入 #1复制

4
ILove
1 Luogu
2 5 5
3 3 guGugu
4 gu

输出 #1复制

ILoveLuogu
Luogu
LuoguGugugu
3

说明/提示

数据保证,1≤�≤1001≤q≤100,开始的字符串长度 ≤100≤100

//写c++的题目肯定是要用stl的,那么下面我们来看接下来的

此篇使用到的库函数:

extern char strcat(char dest, const char src);

strcat 函数将 src 串拼接到 dest 串之后

extern char strstr(char str1, const char str2);

strstr 函数在 str1 串内查找 str2 串的位置,如未找到,则返回 NULL

extern char strcpy(char dest, const char src);

strcpy 函数将 src 串复制到 dest 串

对于以下叙述,我们约定:

���str 串表示原始串, ��in 串表示读入串或暂存串

对于操作 11 :

  • 需使用 strcat 函数

将 ��in 拼接到 ���str 串后

举例:

原始串: ILove

输入: 1 Luogu

操作后

ILoveLuogu(存于 ���str 串)

对于操作 22 :

  • 需使用 strcpy 函数

首先,将 ���str 串第 a + b 位及以后舍去;

接着,将 ���str 串第 a 位及以后复制到 ��in 串中暂存;

最后,将 ��in 串中暂存的内容复制回 ���str 串中。

举例:

原始串: ILoveLuoguMubuky

输入: 2 5 5

第一步操作后:

ILoveLuogu(存于 ���str 串)

第二步操作后:

Luogu(存于 ��in 串)

第三步操作后:

Luogu(存于 ���str 串)

对于操作 33 :

  • 需使用 strcat 函数

首先,将 ���str 串第 a 位及以后的部分接到 ��in 串后;

接着,将 ��in 串接到 ���str 串第 a 位。

举例:

原始串: Luogu

输入: 3 3 guGugu

第一步操作后:

guGugugu(存于 ��in 串)

Luo(存于 ���str 串)

第二步操作后:

LuoguGugugu(存于 ���str 串)

对于操作 44 :

  • 需使用 strstr 函数

查找 ��in 串在 ���str 串中的位置,若函数返回 NULL ,则如题输出 -1,否则将函数返回的指针与字符串串首指针作差以获得其在字符串中的位置。

举例:

原始串: LuoguGugugu

输入: 4 gu

输出: 3

对于strstr函数是子串在母串中出现的次数

#include<stdio.h>
#include<string.h>

int main()
{
    int i,n,j,k=0;
    char a1[1001],a2[1001];
    scanf("%s %s",a1,a2);
    char *p;
    p=a1;
    while( ( p=strstr(p,a2) ) != NULL)//p为子串与母串匹配成功
    {								  //时,子串第一个符号在母串
        k++;						  //中出现的位置地址
        p++; //p++后才能匹配下一个,否则无法退出循环
    }
    printf("%d",k);
}

abababababa
aba
5

下面试完整的代码

#include<stdio.h>
#include<string.h>
#define MAXN 101
char str[MAXN], in[MAXN];
int main(void)
{
	int q;
	scanf("%d\n%s", &q, str);
	for (int i = 1; i <= q; i++) {
		int opt;
		scanf("%d", &opt);
		if (opt == 1) {
			scanf("%s", in);
			strcat(str, in);
			printf("%s\n", str);
		}
		else if (opt == 2) {
			int a, b;
			scanf("%d %d", &a, &b);
			str[a + b] = '\0';
			strcpy(in, &str[a]);
			strcpy(str, in);
			printf("%s\n", str);
		}
		else if (opt == 3) {
			int a;
			scanf("%d %s", &a, in);
			strcat(in, &str[a]);
			printf("%s@",in);
			str[a] = '\0';
			strcat(str, in);
			printf("%s\n", str);
		}
		else {
			scanf("%s", in);
			char *ans = strstr(str, in);
			printf("%d\n", ans != NULL ? (int)(ans - str) : -1);
		}
	}
	return 0;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值