C++ 如何在字符串中查找子串_C++ find 查找子串位置用法

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

c++ 如何在字符串中查找子串_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

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月19日 06:58:03
下一篇 2025年12月10日 07:56:55

相关推荐

发表回复

登录后才能评论
关注微信