C++将<单词 A>替换为<单词包含 A>
C++ replace a <word A> with a <word contains A>
void func(string &s, string const& oldVal, string const& newVal) //function to do the replace
{
while(s.find(oldVal) != string::npos) //keep finding
s.replace(s.find(oldVal), newVal.size(), newVal);
}
int main() //main function, test case
{
string s("tho");
func(s, "tho", "though");
cout << s << endl; // expected output: though.
}
想取代你,好像,但成为一个无限循环。为什么?
尝试如下:
std::string& func(string &s, string const& oldVal, string const& newVal) //function to do the replace
{
size_t pos = 0, fpos;
while((fpos = s.find(oldVal, pos)) != string::npos) //keep finding
{
s.replace(fpos, newVal.size(), newVal);
pos = fpos + newVal.length();
}
return s;
}
在 C++11(或使用 Boost)中,您可以使用regex_replace: http://www.cplusplus.com/reference/regex/regex_replace/
这也应该具有更好的最坏情况复杂性,因为使用字符串替换的代码可能需要复制大量数据,例如:
thothothotho -> (copy 15 characters)
thoughthothotho -> (copy 12 characters)
thoughthoughthotho -> (copy 9 characters)
thoughthoughthoughtho -> (copy 6 characters)
thoughthoughthoughthough
= 总共复制 42 个字符以创建 24 个字符的字符串。在简单示例中还不错,但如您所见,副本数可能会二次增长。
您还可以通过在单次传递中创建结果字符串而不是使用 string::replace 来避免这种情况。
相关文章:
- 请解释这句话(cout<<1+int((a<b)^((b-a)&1) )<<endl
- 呼叫运营商<<临时
- 如何防止clang格式在流运算符调用之间添加换行符<<
- <<操作员在下面的行中工作
- EASTL矢量<向量<int>>连续的
- C - 创建矢量&lt; vector&lt; double&gt;&gt;矩阵具有分配而不是inizializ
- 为什么将此对向量&lt; map&lt; int,int&gt;&gt;中的地图进行更新.失败
- C :对矢量进行排序&lt; struct&gt;(结构有2个整数)基于结构的整数之一
- 明确的专业化“ CheckIntmap&lt;&gt;”实例化
- 什么是模板&lt;&gt;inline bla bla
- 编辑C Qlist&lt; object*&gt; gt;QML代码和一些QML警告中的模型
- eigen :: llt&lt;eigen :: matrixxd&gt;具有不完整的类型
- 错误,包括&lt; ctype&gt;在原子上使用C 11
- std::vector<;uint8_t>;当C++11/14启用时,手动复制而不是调用memcpy
- 如何加入向量&lt; int&gt;到C 中的单个INT
- 是std :: set&lt; std :: future&gt;不可能存在
- 是numeric_limits&lt; int&gt; :: is_modulo从逻辑上矛盾
- opencv 2.4.7在iOS错误背景_segm.hpp #include&lt; list&gt;未找到
- 在修改列表后,std :: list&lt; t&gt; :: end()的值是否会更改
- ///<评论></评论>在Visual Studio中