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 <string>
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 << “子串 ‘” << pattern << “‘ 在位置 ” << found << ” 找到。” << endl;
   } else {
      cout << “未找到子串。” << endl;
   }
   return 0;
}

输出结果:

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

梅子Ai论文

无限免费生成千字论文大纲-在线快速生成论文初稿-查重率10%左右

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

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

子串 ‘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 << “找到 ‘ing’ 在位置: ” << pos << endl;
   pos += 3; // 避免重复匹配
}

基本上就这些。find 函数简单高效,适合大多数子串查找场景。掌握它对处理字符串非常有帮助。

上一篇
下一篇
text=ZqhQzanResources