最常用的方法是使用std::string的find()函数查找子串首次出现位置,若未找到则返回string::npos;示例中查找"welcome"在字符串中的位置并输出结果;find支持多种参数形式,如C风格字符串、单个字符等;可通过循环调用find查找所有匹配位置。

在 C++ 中查找字符串中的子串,最常用的方法是使用 std::string 类提供的 find() 函数。这个函数能返回子串首次出现的位置,如果未找到则返回一个特殊值 std::string::npos。
函数原型如下:
size_t find(const string& str, size_t pos = 0) const;参数说明:
返回值是子串第一次出现的起始索引(从 0 开始),若未找到则返回 string::npos。
立即学习“C++免费学习笔记(深入)”;
下面是一个简单示例:
#include <iostream>int main() {
string text = "Hello, welcome to C++ programming!";
string pattern = "welcome";
size_t found = text.find(pattern);
if (found != string::npos) {
cout << "子串 '" << pattern << "' 在位置 " << found << " 找到。" << endl;
} else {
cout << "未找到子串。" << endl;
}
return 0;
}
输出结果:
子串 'welcome' 在位置 7 找到。除了查找 string 对象,find 还支持多种输入类型:
例如查找字符:
size_t pos = text.find('C'); // 查找字符 'C'string::npos 是一个常量,通常为 -1 转换为 size_t 类型(即最大无符号整数值)。判断是否找到时一定要使用 != npos,不能直接与数字比较。
如果想查找所有匹配位置,可以循环调用 find,并更新起始位置:
size_t pos = 0;基本上就这些。find 函数简单高效,适合大多数子串查找场景。掌握它对处理字符串非常有帮助。
以上就是C++ 如何在字符串中查找子串_C++ find 查找子串位置用法的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号