然而沼跃鱼早就看穿了一切

来源:互联网 发布:哪家运营商4g网络最好 编辑:程序博客网 时间:2024/06/02 22:46

问题:

描述


fjxmlhx每天都在被沼跃鱼刷屏,因此他急切的找到了你希望你写一个程序屏蔽所有句子中的沼跃鱼(“marshtomp”,不区分大小写)。为了使句子不缺少成分,统一换成 “fjxmlhx” 。

输入

输入包括多行。

每行是一个字符串,长度不超过200。

一行的末尾与下一行的开头没有关系。

输出

输出包含多行,为输入按照描述中变换的结果。

样例输入
The Marshtomp has seen it all before.marshTomp is beaten by fjxmlhx!AmarshtompB
样例输出
The fjxmlhx has seen it all before.fjxmlhx is beaten by fjxmlhx!AfjxmlhxB

解法:

    该题的思路很简单,用一个指针在原字串中移动,将所有非要找的字串拷贝到一个新的字串中,而将要找的字串替换为要替换的字串。

#include<iostream>#include<string>using namespace std;char changeLB(char src){if(src >= 'a' && src <= 'z'){return src - ('a' - 'A');}else{return src + 'a' - 'A';}}string execReplace(string src, string tofind = "marshTomp", string toreplace = "fjxmlhx"){int i = 0;string result;while(i < src.length()){if(src[i] != tofind[0] && src[i] != changeLB(tofind[0])){result += src[i];i++;}else{int j = 0;int tmp = i;while(i < src.length() && j < tofind.length()){if(src[i] == tofind[j] || src[i] == changeLB(tofind[j])){i++;j++;}else{break;}}if(j == tofind.length()){result += toreplace;    }else{result += src[tmp];i = tmp + 1;}}}return result;}int main(int argc, char **argv){string tochange;while(getline(cin, tochange)){cout << execReplace(tochange) << endl;    }return 0;}
0 0
原创粉丝点击