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

在 C++ 中查找字符串中的子串,最常用的方法是使用 std::string 类提供的 find() 函数。这个函数能返回子串首次出现的位置,如果未找到则返回一个特殊值 std::string::npos。
find() 基本用法
函数原型如下:
size_t find(const string& str, size_t pos = 0) const;
参数说明:
str:要查找的子串pos:从字符串的哪个位置开始查找,默认从索引 0 开始
返回值是子串第一次出现的起始索引(从 0 开始),若未找到则返回 string::npos。
立即学习“C++免费学习笔记(深入)”;
查找子串示例代码
下面是一个简单示例:
#include iostream>
#include
using namespace std;
int main() {
string text = “Hello, welcome to C++ programming!”;
string pattern = “welcome”;
size_t found = text.find(pattern);
if (found != string::npos) {
cout } else {
cout }
return 0;
}
输出结果:
子串 ‘welcome’ 在位置 7 找到。
其他查找形式
除了查找 string 对象,find 还支持多种输入类型:
find(const char* s):查找 C 风格字符串find(const char* s, size_t pos):从指定位置查找 C 字符串find(char c):查找单个字符find(char c, size_t pos):从指定位置查找字符
例如查找字符:
size_t pos = text.find(‘C’); // 查找字符 ‘C’
注意事项
string::npos 是一个常量,通常为 -1 转换为 size_t 类型(即最大无符号整数值)。判断是否找到时一定要使用 != npos,不能直接与数字比较。
如果想查找所有匹配位置,可以循环调用 find,并更新起始位置:
size_t pos = 0;
while ((pos = text.find(“ing”, pos)) != string::npos) {
cout pos += 3; // 避免重复匹配
}
基本上就这些。find 函数简单高效,适合大多数子串查找场景。掌握它对处理字符串非常有帮助。
以上就是C++ 如何在字符串中查找子串_C++ find 查找子串位置用法的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1483112.html
微信扫一扫
支付宝扫一扫