大致的思路,先从头到尾扫描下整个字符串,得到有多少个需要被替换的目标字符串,然后通过 find() 和replace() 两个函数将其替换。
但是感觉如果这种处理方式,对一个非常巨大的字符串会耗费相当大的时间,暂时没想出什么好的方法。
#include "iostream"
#include "string"
using namespace std;
string findtoReplace(string str,string rep,string result_rep){
int str_size = str.size();
int str_replaceAccout = 0;
string result_str = ""; //最后输出的结果
string outinput_str = str;
string symbol = rep; //想要代替的符号
string result_symbol = result_rep; //代替的符号
string judgement = "";
for (int i = 0; i < str_size; ++i)
{
judgement = outinput_str[i];
if (judgement == symbol)
{
str_replaceAccout++;
}
}
for (int i = str_replaceAccout; i > 0; i--)
{
outinput_str.replace(outinput_str.find(" "),1,result_symbol);
}
result_str = outinput_str;
return result_str;
}
int main(int argc, char const *argv[])
{
string str = "I am student!";
string wanttorep = "@";
string rep = " ";
cout<<findtoReplace(str,rep,wanttorep);
return 0;
}