题目来源:codeup 字符串的查找删除
题目描述
给定一个短字符串(不含空格),再给定若干字符串,在这些字符串中删除所含有的短字符串。
输入
输入只有1组数据。
输入一个短字符串(不含空格),再输入若干字符串直到文件结束为止。
输出
删除输入的短字符串(不区分大小写)并去掉空格,输出。
样例输入
in
#include
int main()
{
printf(" Hi ");
}
样例输出
#clude
tma()
{
prtf(“Hi”);
}
提示
注:将字符串中的In、IN、iN、in删除。
#include <iostream>
#include <string>
using namespace std;
int main()
{
string s, str;
getline(cin, s);
int len = s.length();
while (getline(cin, str))
{
if (str.length() < len)
{
cout << str << endl;
continue;
}
for (int i = 0; i < str.length() - len + 1; i++)
{
bool flag = true;
for (int j = i; j < i + len; j++)
{
if (str[j] != s[j - i] && str[j] != s[j - i] - 32 && str[j] != s[j - i] + 32)
{
flag = false;
break;
}
}
if (flag)
{
for (int j = i; j < i + len; j++)
str[j] = '`';
}
}
for (int i = 0; i < str.length(); i++)
{
if (str[i] != '`' && str[i] != ' ')
cout << str[i];
}
cout << endl;
}
return 0;
}
#include <iostream>
#include <string>
using namespace std;
int main()
{
string s, str;
getline(cin, s);
int len = s.length();
while (getline(cin, str))
{
if (str.length() < len)
{
cout << str << endl;
continue;
}
int len2 = str.length();
for (int j = 0, k = 0; j < len2;)
{
if (str[j + k] == s[k] || str[j+k] == s[k] - 32 || str[j+k] == s[k] + 32)
{
k++;
if (k == len)
{
j = j + k;
k = 0;
}
}
else
{
if (str[j] != ' ')
{
cout << str[j];
}
j++;
k = 0;
}
}
cout<<endl;
}
return 0;
}