输入 2 2 2 个字符串 S 1 S1 S1 和 S 2 S2 S2,要求删除字符串 S 1 S1 S1 中出现的所有子串 S 2 S2 S2,即结果字符串中不能包含 S 2 S2 S2。
输入在 2 2 2 行中分别给出不超过 80 80 80 个字符长度的、以回车结束的 2 2 2 个非空字符串,对应 S 1 S1 S1 和 S 2 S2 S2。
在一行中输出删除字符串 S 1 S1 S1 中出现的所有子串 S 2 S2 S2 后的结果字符串。
Tom is a male
首先利用 g e t l i n e ( ) getline() getline() 函数分别读入字符串和要删除的字符串;然后使用 f i n d ( ) find() find() 函数查找 s t r str str 字符串中是否有和 s s s 字符串完全一样的部分,如果没有找到直接输出字符串 s t r str str 即可;如果找到则利用 e r a s e ( ) erase() erase() 函数将字符串 s t r str str 中与 s s s 字符串完全一样的部分删除,然后输出即可。
#include<string>
#include<iostream>
using namespace std;
int main(void)
{
string str, s;
cout << "请输入两个字符串:"; // 提交时注释此行
getline(cin, str);
getline(cin, s);
while (str.find(s) < str.length()) // find()函数用法:x.find(y); 在x中找y
str = str.erase(str.find(s), s.length()); // erase()函数用法:str.erase(x,y); 从位置x处开始,删除y个字符
cout << str << endl;
return 0;
}
因篇幅问题不能全部显示,请点此查看更多更全内容
Copyright © 2019- igbc.cn 版权所有 湘ICP备2023023988号-5
违法及侵权请联系:TEL:199 1889 7713 E-MAIL:2724546146@qq.com
本站由北京市万商天勤律师事务所王兴未律师提供法律服务