我是靠谱客的博主 文艺花瓣,这篇文章主要介绍B : DS串应用–串替换B : DS串应用–串替换,现在分享给大家,希望可以做个参考。

B : DS串应用–串替换

复制代码
1
2
3
4
5
Time Limit: 1 Sec Memory Limit: 128 Mb Submitted: 23 Solved: 17

Description

给出主串、模式串、替换串,用KMP算法找出模式串在主串的位置,然后用替换串的字符替换掉模式串

本题只考虑一处替换的情况,如果你想做的完美一些,能够实现多处替换那可能需要考虑模式串和替换串长度不一致的情况

Input

第一个输入t,表示有t个实例

第二行输入第1个实例的主串,第三行输入第1个实例的模式串,第四行输入第1个实例的替换串

以此类推

Output

第一行输出第1个实例的主串

第二行输出第1个实例的主串替换后结果,如果没有发生替换就输出主串原来的内容。

以此类推

Sample Input

4
aabbccdd
bb
ff
aaabbbccc
ddd
eee
abcdef
abc
ccccc
abcdef
abc
c

Sample Output

aabbccdd
aaffccdd
aaabbbccc
aaabbbccc
abcdef
cccccdef
abcdef
cdef

解题思路:KMP的具有高效字符串匹配优势。
在这里编写出KMP模板后,用KMP查找字符串b在a中位置,查找到后用string 的内置函数erase(位置,删除个数)来删掉,
然后用insert(位置,字符串)插入进去。

ac代码如下:

复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
#include<iostream> using namespace std; int nextt[1000000]; void Get_next(string a) { int i=0,k=-1; int len=a.length(); nextt[0]=-1; while(i<len) { if(k==-1||a[i]==a[k]) { i++,k++; nextt[i]=k; } else k=nextt[k]; } } int KMP(string a,string b) { int i=0,j=0; int len=a.length(),len1=b.length(); Get_next(b); while(i<len&&j<len1) { if(j==-1||a[i]==b[j])i++,j++; else j=nextt[j]; } if(j==len1)return i-j; else return -1; } int main() { string a,b,c; int n; cin>>n; while(n--) { cin>>a>>b>>c; cout<<a<<endl; int m=KMP(a,b); if(m!=-1) { a.erase(m,b.length()); a.insert(m,c); } cout<<a<<endl; } return 0; }

最后

以上就是文艺花瓣最近收集整理的关于B : DS串应用–串替换B : DS串应用–串替换的全部内容,更多相关B内容请搜索靠谱客的其他文章。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(69)

评论列表共有 0 条评论

立即
投稿
返回
顶部