C++中查找子串常用std::string的find()函数,它返回子串首次出现的位置,未找到则返回std::string::npos;还可使用rfind()从右查找、实现忽略大小写查找或借助<regex>进行复杂匹配。

在C++中查找字符串中的子串,常用的方法依赖于标准库std::string提供的成员函数。这些方法简单高效,适合大多数场景。
find() 是最常用的子串查找方式,它返回子串第一次出现的位置索引,如果未找到则返回 std::string::npos。
size_t 类型,表示匹配位置的下标(从0开始)std::string::npos(通常为 -1 转换为无符号最大值)示例代码:
#include <iostream>
#include <string>
int main() {
std::string str = "Hello, welcome to C++ programming!";
std::string substr = "welcome";
size_t pos = str.find(substr);
if (pos != std::string::npos) {
std::cout << "子串在位置 " << pos << " 找到。\n";
} else {
std::cout << "未找到子串。\n";
}
return 0;
}
C++ 提供了多个 find 相关函数,满足不同查找需求:
立即学习“C++免费学习笔记(深入)”;
若只想找完整子串,应使用 find() 或 rfind()。
标准库没有直接提供忽略大小写的查找,需手动实现。常见做法是将原字符串和子串都转为小写后再查找。
示例:
#include <iostream>
#include <string>
#include <algorithm>
#include <cctype>
std::string toLower(const std::string& s) {
std::string lower = s;
std::transform(lower.begin(), lower.end(), lower.begin(), ::tolower);
return lower;
}
size_t findIgnoreCase(const std::string& str, const std::string& substr) {
return toLower(str).find(toLower(substr));
}
int main() {
std::string text = "C++ is awesome!";
std::string key = "c++";
if (findIgnoreCase(text, key) != std::string::npos) {
std::cout << "找到了(忽略大小写)\n";
}
return 0;
}
基本上就这些。对于常规子串查找,find() 完全够用。需要更复杂模式匹配时,可考虑使用 <regex> 库。不过对于简单查找,std::string::find 更轻量、易读、高效。
以上就是c++++中怎么查找字符串中的子串_c++字符串查找实现方式的详细内容,更多请关注php中文网其它相关文章!
c++怎么学习?c++怎么入门?c++在哪学?c++怎么学才快?不用担心,这里为大家提供了c++速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号