C/C++編程判斷String字符串是否包含某個(gè)字符串實(shí)現(xiàn)示例
一、C語(yǔ)言風(fēng)格
在C語(yǔ)言中,字符串存儲(chǔ)為字符數(shù)組,以'\0'結(jié)束。
在C的接口中,有strstr函數(shù),可以在字符串中查找另一個(gè)字符串。
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" ;
char *c= "123" ;
if ( strstr (a.c_str(), b) == NULL) //在a中查找b,如果不存在,
cout << "not found\n" ; //輸出結(jié)果。
else //否則存在。
cout << "found\n" ; //輸出結(jié)果。
if ( strstr (a.c_str(), c) == NULL) //在a中查找b,如果不存在,
cout << "not found\n" ; //輸出結(jié)果。
else //否則存在。
cout << "found\n" ; //輸出結(jié)果。
return 0;
}
二、C++風(fēng)格
C++的string類提供了字符串中查找另一個(gè)字符串的函數(shù)find。
其重載形式為:
string::size_type string::find(string &);
功能為在string對(duì)象中,查找參數(shù)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;
}
兩種方法在實(shí)際編程中都可以使用,效率幾乎相同。
不過相對(duì)來說使用C++的string效率更高一些,代碼也更簡(jiǎn)便。
以上就是C++編程判斷String字符串是否包含某個(gè)字符串實(shí)現(xiàn)示例的詳細(xì)內(nèi)容,更多關(guān)于C++判斷String字符串是否包含某個(gè)字符串的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
C語(yǔ)言實(shí)現(xiàn)停車場(chǎng)管理
這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言課程設(shè)計(jì)之停車場(chǎng)管理問題,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-12-12
Qt項(xiàng)目實(shí)戰(zhàn)之方塊游戲的實(shí)現(xiàn)
這篇文章主要為大家詳細(xì)介紹了如何利用Qt實(shí)現(xiàn)簡(jiǎn)易的方塊游戲,文中的示例代碼講解詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴可以了解一下2023-03-03
C語(yǔ)言單向鏈表的表示與實(shí)現(xiàn)實(shí)例詳解
這篇文章主要介紹了C語(yǔ)言單向鏈表的表示與實(shí)現(xiàn),需要的朋友可以參考下2014-07-07
淺談十進(jìn)制小數(shù)和二進(jìn)制小數(shù)之間的轉(zhuǎn)換
下面小編就為大家?guī)硪黄獪\談十進(jìn)制小數(shù)和二進(jìn)制小數(shù)之間的轉(zhuǎn)換。小編覺得挺不錯(cuò)的現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-01-01
MongoDB?C?驅(qū)動(dòng)程序安裝(libmongoc)?和?BSON?庫(kù)(libbson)方法
這篇文章主要介紹了安裝?MongoDB?C?驅(qū)動(dòng)程序?(libmongoc)?和?BSON?庫(kù)?(libbson),本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-09-09
VC運(yùn)用OPENGL加載BMP紋理圖的實(shí)現(xiàn)方法匯總
這篇文章主要介紹了VC運(yùn)用OPENGL加載BMP紋理圖的實(shí)現(xiàn)方法,對(duì)于更好的了解OpenGL很有幫助,需要的朋友可以參考下2014-07-07
c++詳細(xì)講解構(gòu)造函數(shù)的拷貝流程
拷貝構(gòu)造函數(shù)是一種特殊的構(gòu)造函數(shù),它在創(chuàng)建對(duì)象時(shí),是使用同一類中之前創(chuàng)建的對(duì)象來初始化新創(chuàng)建的對(duì)象。拷貝構(gòu)造函數(shù)通常用于:通過使用另一個(gè)同類型的對(duì)象來初始化新創(chuàng)建的對(duì)象。?復(fù)制對(duì)象把它作為參數(shù)傳遞給函數(shù)。復(fù)制對(duì)象,并從函數(shù)返回這個(gè)對(duì)象2022-05-05

