大家早上好,几天前我正在思考,我找不到解决办法。
我需要仅使用字符串类更改字符串中的多个字符。
我尝试使用替换功能,但只替换一个字符。
示例:
ORIGINAL STRING:“Hola Pepe,com va la vida”
输入要替换的字符 你好 输入要替换它的字符 *
H * l * P * p *,c * m v * l * v * d *
谢谢大家。
答案 0 :(得分:5)
我认为最可行的方法就是使用std::transform
:
#include <algorithm>
...
std::set<char> vowels = {'a', 'o', 'e', 'i', 'u'};
char change_to = '*';
std::string s = "Hola Pepe, com va la vida";
auto transformation_operation = [vowels, change_to](char c)
{
return vowels.count(c) ? change_to : c;
};
std::transform(s.begin(), s.end(), s.begin(), transformation_operation);
这里transformation_operation
是一个lambda,它实际上以理想的方式转换一个char(如果你愿意,可以以函数或类的形式实现)。为此,它使用捕获的vowels
和字符change_to
集。要添加更多细节,它会检查vowels
集中是否存在该字符,如果存在,则返回change_to
,如果不存在,则返回原始字符。
std::transform
为从s.begin()
到s.end()
的每个元素调用此lambda,存储以s.begin()
开头的结果,即就地。
答案 1 :(得分:0)
我建议使用std::string
方法find_first_of
。
例如
#include <iostream>
#include <string>
int main()
{
std::string s("Hola Pepe, com va la vida");
std::string t("aeiou");
char c = '*';
std::cout << s << std::endl;
for (std::string::size_type pos = 0;
(pos = s.find_first_of(t, pos)) != std::string::npos;
++pos)
{
//s.replace(pos, 1, 1, c);
s[pos] = c;
}
std::cout << s << std::endl;
}
程序输出
Hola Pepe, com va la vida
H*l* P*p*, c*m v* l* v*d*
如果要使用标准算法,那么我认为在这种情况下最合适的算法是std::replace_if
。例如
#include <iostream>
#include <string>
#include <set>
#include <algorithm>
int main()
{
std::string s("Hola Pepe, com va la vida");
std::set<char> t({ 'a', 'e', 'i', 'o', 'u' });
char c = '*';
std::cout << s << std::endl;
std::replace_if(s.begin(), s.end(),
[&t](char c) { return t.count(c); }, c);
std::cout << s << std::endl;
}
程序输出与上面显示的相同
Hola Pepe, com va la vida
H*l* P*p*, c*m v* l* v*d*