c++如何查找字符串中的子串_C++字符串查找find函数用法

find函数用于查找子串首次出现位置,返回索引或npos;可指定起始位置查找多个匹配;还提供rfind、find_first_of等扩展函数。

c++如何查找字符串中的子串_c++字符串查找find函数用法

在C++中,查找字符串中的子串是一个常见操作。标准库中的std::string类提供了find()函数,可以高效地完成这一任务。这个函数返回子串首次出现的位置,如果未找到则返回std::string::npos。

find函数基本语法

find()函数有多种重载形式,最常用的是:

size_t find(const string& str, size_t pos = 0) const;
size_t find(const char* s, size_t pos = 0) const;

参数说明:

str / s:要查找的子串pos:从字符串的哪个位置开始查找,默认从0开始

返回值为size_t类型,表示子串第一次出现的起始索引。若未找到,返回std::string::npos(通常为-1转换成无符号整数)。

立即学习“C++免费学习笔记(深入)”;

查找子串的使用示例

下面是一个简单的例子,演示如何使用find()查找子串:

#include iostream>
#include
using namespace std;

int main() {
    string text = “Hello, welcome to C++ programming!”;
    string pattern = “C++”;

    size_t found = text.find(pattern);
    if (found != string::npos) {
        cout     } else {
        cout     }
    return 0;
}

输出结果:

子串 ‘C++’ 在位置 17 找到。

从指定位置开始查找

可以通过第二个参数指定查找起始位置,适用于需要查找多个匹配项的情况:

size_t pos = 0;
while ((pos = text.find(“o”, pos)) != string::npos) {
    cout     pos++; // 移动到下一个位置,避免无限循环
}

这段代码会找出所有字母’o’的出现位置。

其他查找函数

除了find(),std::string还提供了一些类似的查找函数:

rfind():从右往左查找,返回最后一次出现的位置find_first_of():查找任意一个匹配字符的首次出现find_last_of():查找任意一个匹配字符的最后一次出现find_first_not_of()find_last_not_of():查找不匹配的字符

这些函数适用于更复杂的匹配需求。

基本上就这些。掌握find()函数的用法,能有效处理大多数字符串查找问题。注意判断返回值是否为npos,避免访问非法位置。不复杂但容易忽略细节。

以上就是c++++如何查找字符串中的子串_C++字符串查找find函数用法的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1482245.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月19日 06:12:25
下一篇 2025年12月19日 06:12:45

相关推荐

发表回复

登录后才能评论
关注微信