|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
题目
回文树
说明
给你一个文本串 S ,再给你两个串A、B,你要将文本串中的 A 从左到右都转换成 B ,转换后的字符不再参与转换,输出最终的文本串。
输入格式
第一行输入一个文本串 S 。
第二行输入字符串 A 。
第三行输入字符串 B 。
|S|为S的长度,|A|为A的长度,|B|为B的长度,所有字符都是小写字母,保证 |A| <= |S| 。
对于ABC的长度,1<= |A|、|B|<=10,1<= |S|<=200
输出格式
只有一行,输出转换后的文本串,从左到右依次替换。
样例
输入数据 1
输出数据 1
我的代码:
- #include <bits/stdc++.h>
- using namespace std;
- int main(){
- string S,A,B,s1="";
- cin >>S>>A>>B;
- for(int i=0;i<=int(S.size())-int(A.size());i++){
- if(S.substr(i,int(A.size()))==A){
- s1+=B;
- i++;
- }else s1+=S[i];
- }
- cout<<s1;
- }
复制代码
你的代码基本上是正确的,但是在找到匹配的子串后,你使用了 i++来跳过匹配的部分,这可能导致一些错误。另外,使用 bits/stdc++.h是不推荐的,应该只包含需要的头文件。
以下是修改后的代码:
- #include <iostream>
- #include <string>
- using namespace std;
- int main() {
- string S, A, B;
- string s1 = "";
- cin >> S >> A >> B;
-
- int i = 0;
- while (i <= int(S.size()) - int(A.size())) {
- if (S.substr(i, int(A.size())) == A) {
- s1 += B;
- i += int(A.size());
- } else {
- s1 += S[i];
- i++;
- }
- }
-
- cout << s1;
- return 0;
- }
复制代码
希望对你有所帮助!如果还有其他问题,请随时提问。
球一个最佳答案谢谢啦!这对我非常重要!  
|
|