C++中查找子串最常用find函数,它返回首次匹配位置或npos;支持从指定位置搜索以查找多个结果;还提供rfind等变体用于反向或字符集查找;结合algorithm库可实现更复杂匹配逻辑。

在C++中查找字符串中的子串,最常用的方法是使用标准库
std::string提供的
find函数。它功能强大、使用简单,能快速定位子串的位置。如果想实现更复杂的匹配逻辑,也可以结合其他方法或算法。
1. 使用 find 函数查找子串
find是
std::string类的成员函数,用于在字符串中查找指定的子串或字符。如果找到,返回子串首次出现的起始索引;未找到则返回常量
std::string::npos。
基本语法:
size_t pos = str.find("子串");示例代码:
立即学习“C++免费学习笔记(深入)”;
#include iostream>#include
using namespace std;
int main() {
string text = "Hello, welcome to C++ programming!";
string pattern = "welcome";
size_t pos = text.find(pattern);
if (pos != string::npos) {
cout } else {
cout }
return 0;
}
输出结果:
子串在位置 7 处找到。2. 从指定位置开始查找
find支持从某个位置开始搜索,适用于查找多个匹配项。
语法:
示例:查找所有匹配的子串位置
size_t pos = 0;while ((pos = text.find("o", pos)) != string::npos) {
cout pos++; // 移动到下一个位置,避免重复匹配同一位置
}
3. 其他查找函数
C++还提供了一些
find的变体,满足不同需求:
- rfind():从右往左查找,返回最后一次出现的位置。
- find_first_of():查找参数中任意一个字符首次出现的位置。
- find_last_of():查找参数中任意一个字符最后一次出现的位置。
- find_first_not_of():查找第一个不在指定字符集中的字符。
- find_last_not_of():查找最后一个不在指定字符集中的字符。
例如,查找最后一个 "o" 的位置:
size_t pos = text.rfind('o');4. 使用算法库 find + 容器方式(进阶)
对于更灵活的操作,可以将字符串视为字符容器,使用
中的
std::search或
std::find_end。
示例:使用
std::search#include
auto it = search(text.begin(), text.end(), pattern.begin(), pattern.end());
if (it != text.end()) {
cout }
这种方式适合自定义匹配规则,比如忽略大小写等。
基本上就这些。日常开发中,
find函数已经足够应对大多数字符串查找需求,简洁高效。注意判断返回值是否为
string::npos,避免误用无效位置。不复杂但容易忽略。










