C++ string 字符串查找匹配實例代碼
在寫C++程序中,總會遇到要從一個字符串中查找一小段子字符串的情況,對于在C中,我們經(jīng)常用到strstr()或者strchr()這兩種方法。而對于C++的string,我們往往會用到find()。
C++:#inlcude<string>
C: #include<string.h>
find():在一個字符串中查找一個指定的單個字符或字符數(shù)組。如果找到,就返回首次匹配的開始位置;如果沒有查找到匹配的內(nèi)容,就返回string::npos。
find_first_of():在一個目標串中進行查找,返回值是第一個與指定字符組中任何字符匹配的字符位置。如果沒有查找到匹配的內(nèi)容,則返回npos。
find_last_of():在一個目標串中進行查找,返回最后一個與指定字符組中任何字符匹配的字符位置。如果沒有查找到匹配的內(nèi)容,則返回npos。
find_first_not_of():在一個目標串中進行查找,返回第一個與指定字符組中任何字符都不匹配的元素位置。如果找不到那樣的元素則返回npos。
find_last_not_of():在一個目標串中進行查找,返回下標值最大的與指定字符組中任何字符都不匹配的元素的位置。若找不到那樣的元素則返回npos。
rfind():對一個串從尾至頭查找一個指定的單個字符或字符組。如果找到,就返回首次匹配的開始位置;如果沒有查找到匹配的內(nèi)容,則返回npos。
find(string, int):第一個參數(shù)用來指示要查找的字符,第二個參數(shù)用來表示從字符串的何處開始查找子串(默認的查找位置是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ī)淼腃++ string 字符串查找匹配實例代碼全部內(nèi)容了,希望大家多多支持腳本之家~
相關文章
數(shù)據(jù)結構 C語言實現(xiàn)循環(huán)單鏈表的實例
這篇文章主要介紹了數(shù)據(jù)結構 C語言實現(xiàn)循環(huán)單鏈表的實例的相關資料,需要的朋友可以參考下2017-05-05
C語言實現(xiàn)通訊錄的方法(包括靜態(tài)版本和動態(tài)版本)
本文給大家分享C語言實現(xiàn)通訊錄的方法(包括靜態(tài)版本和動態(tài)版本),針對每種方法給大家介紹的非常詳細,需要的朋友參考下吧2021-09-09
關于虛函數(shù)實現(xiàn)多態(tài)的原理及分析
這篇文章主要介紹了C++中如何實現(xiàn)多態(tài)問題,具有很好的參考價值,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-02-02

