C++ string 字符串查找匹配實(shí)例代碼
在寫(xiě)C++程序中,總會(huì)遇到要從一個(gè)字符串中查找一小段子字符串的情況,對(duì)于在C中,我們經(jīng)常用到strstr()或者strchr()這兩種方法。而對(duì)于C++的string,我們往往會(huì)用到find()。
C++:#inlcude<string>
C: #include<string.h>
find():在一個(gè)字符串中查找一個(gè)指定的單個(gè)字符或字符數(shù)組。如果找到,就返回首次匹配的開(kāi)始位置;如果沒(méi)有查找到匹配的內(nèi)容,就返回string::npos。
find_first_of():在一個(gè)目標(biāo)串中進(jìn)行查找,返回值是第一個(gè)與指定字符組中任何字符匹配的字符位置。如果沒(méi)有查找到匹配的內(nèi)容,則返回npos。
find_last_of():在一個(gè)目標(biāo)串中進(jìn)行查找,返回最后一個(gè)與指定字符組中任何字符匹配的字符位置。如果沒(méi)有查找到匹配的內(nèi)容,則返回npos。
find_first_not_of():在一個(gè)目標(biāo)串中進(jìn)行查找,返回第一個(gè)與指定字符組中任何字符都不匹配的元素位置。如果找不到那樣的元素則返回npos。
find_last_not_of():在一個(gè)目標(biāo)串中進(jìn)行查找,返回下標(biāo)值最大的與指定字符組中任何字符都不匹配的元素的位置。若找不到那樣的元素則返回npos。
rfind():對(duì)一個(gè)串從尾至頭查找一個(gè)指定的單個(gè)字符或字符組。如果找到,就返回首次匹配的開(kāi)始位置;如果沒(méi)有查找到匹配的內(nèi)容,則返回npos。
find(string, int):第一個(gè)參數(shù)用來(lái)指示要查找的字符,第二個(gè)參數(shù)用來(lái)表示從字符串的何處開(kāi)始查找子串(默認(rèn)的查找位置是0)。
舉例:字符串匹配:
#include "stdafx.h" #include<iostream> #include<math.h> #include<string> using namespace std; int _tmain(int argc, _TCHAR* argv[]) { string T;//原串 string P;//模式 while(cin>>T>>P) { int count=0; int begin=-1; while((begin=T.find(P,begin+1))!=string::npos) { count++; } cout<<count<<endl; } int z; cin>>z; return 0; }
以上就是小編為大家?guī)?lái)的C++ string 字符串查找匹配實(shí)例代碼全部?jī)?nèi)容了,希望大家多多支持腳本之家~
相關(guān)文章
Linux系統(tǒng)下如何使用C++解析json文件詳解
JSON(JavaScript Object Notation, JS 對(duì)象簡(jiǎn)譜) 是一種輕量級(jí)的數(shù)據(jù)交換格式。下面這篇文章主要給大家介紹了關(guān)于Linux系統(tǒng)下如何使用C++解析json文件的相關(guān)資料,需要的朋友可以參考下2021-06-06C語(yǔ)言實(shí)現(xiàn)點(diǎn)餐系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言實(shí)現(xiàn)點(diǎn)餐系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-11-11C語(yǔ)言時(shí)間函數(shù)之strftime()詳解
這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言時(shí)間函數(shù)之strftime(),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來(lái)幫助2022-02-02Linux下C語(yǔ)言的fork()子進(jìn)程函數(shù)用法及相關(guān)問(wèn)題解析
fork()函數(shù)在Linux下可以用于產(chǎn)生一個(gè)子進(jìn)程,這里我們挑選了兩個(gè)fork相關(guān)的面試題,來(lái)看一下Linux下C語(yǔ)言的fork()子進(jìn)程函數(shù)用法及相關(guān)問(wèn)題解析2016-06-06C++ 如何將string轉(zhuǎn)換成全小寫(xiě)
這篇文章主要介紹了C++ 如何將string轉(zhuǎn)換成全小寫(xiě)問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。2022-11-11C++任意線程通過(guò)hwnd實(shí)現(xiàn)將操作發(fā)送到UI線程執(zhí)行
做Windows界面開(kāi)發(fā)時(shí),經(jīng)常需要在多線程環(huán)境中將操作拋到主線程執(zhí)行,下面我們就來(lái)學(xué)習(xí)一下如何在不需要重新定義消息以及接收消息的情況下實(shí)現(xiàn)這一要求,感興趣的可以了解下2024-03-03數(shù)據(jù)結(jié)構(gòu)之?dāng)?shù)組Array實(shí)例詳解
這篇文章主要介紹了數(shù)據(jù)結(jié)構(gòu)之?dāng)?shù)組Array實(shí)例詳解的相關(guān)資料,需要的朋友可以參考下2017-05-05