std::string如何查找全部出现的字符
时间: 2023-08-03 12:08:41 浏览: 82
求字符的所有排列
std::string中可以使用find函数的重载版本来查找全部出现的字符。具体方法是:
```c++
std::string str = "hello world";
std::string sub_str = "l";
size_t pos = str.find(sub_str);
while (pos != std::string::npos) {
std::cout << "子串出现的位置为:" << pos << std::endl;
pos = str.find(sub_str, pos+1);
}
```
在这个例子中,我们首先使用find函数查找子串在字符串中第一次出现的位置,然后在while循环中不断调用find函数,并将上一次查找到的位置加1作为下一次查找的起始位置。当find函数返回std::string::npos时,表示字符串中没有找到子串,循环结束。
需要注意的是,在使用find函数查找全部出现的字符时,我们需要将上一次查找到的位置加1作为下一次查找的起始位置。这是因为,find函数默认从字符串的起始位置开始查找,如果不加1的话,会重复查找已经查找过的位置。
另外,如果需要查找多个字符,可以将查找的子串设为单个字符,然后使用循环查找全部出现的字符。
阅读全文