判断一个字符串是否为另一个字符串的子串
1、string类函数find
C++的string类提供了字符串中查找另一个字符串的函数find。
其重载形式为:string::size_type string::find(string &);
功能为在string对象中,查找参数string类型的字符串是否存在,如果存在,返回起始位置。不存在则返回 string::npos。
#include <iostream>
#include <string>
using namespace std;
int main()
{
string a="abcdefghigklmn";
string b="def";
string c="123";
string::size_type idx;
idx=a.find(b);//在a中查找b.
if(idx == string::npos )//不存在
cout << "not found\n";
else//存在
cout <<"found\n";
idx=a.find(c);//在a中查找c。
if(idx == string::npos )//不存在
cout << "not found\n";
else//存在
cout <<"found\n";
return 0;
}
2、strstr函数
在C语言中,字符串存储为字符数组,以'\0'结束。 在C的接口中,有strstr函数,可以在字符串中查找另一个字符串。
char * strstr(const char *str1, const char *str2);
功能为在str1中查找str2,如果存在,那么返回查找到的起始指针,否则返回NULL。
#include <iostream>
#include <string>
#include <cstring>
using namespace std;
int main()
{
string a="abcdefghigklmn";
char *b="def";
string c="123";
if(strstr(a.c_str(), b) == NULL)//在a中查找b,不存在
cout << "not found\n";
else//否则存在
cout <<"found\n";
if(strstr(a.c_str(), c.c_str()) == NULL)//在a中查找c,不存在
cout << "not found\n";
else//否则存在
cout <<"found\n";
return 0;
}
————————————————
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
原文链接:https://blog.csdn.net/u013925378/article/details/91971854
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 地球OL攻略 —— 某应届生求职总结
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 提示词工程——AI应用必不可少的技术
· .NET周刊【3月第1期 2025-03-02】