C++ string 字符串查找匹配

在寫C++程序中,總會遇到要從一個字符串中查找一小段子字符串的狀況,對於在C中,咱們常常用到strstr()或者strchr()這兩種方法。而對於C++的string,咱們每每會用到find()。html

C++:#inlcude<string>
C: #include<string.h>

find():在一個字符串中查找一個指定的單個字符或字符數組。若是找到,就返回首次匹配的開始位置;若是沒有查找到匹配的內容,就返回string::npos。
find_first_of():在一個目標串中進行查找,返回值是第一個與指定字符組中任何字符匹配的字符位置。若是沒有查找到匹配的內容,則返回npos。
find_last_of():在一個目標串中進行查找,返回最後一個與指定字符組中任何字符匹配的字符位置。若是沒有查找到匹配的內容,則返回npos。
find_first_not_of():在一個目標串中進行查找,返回第一個與指定字符組中任何字符都不匹配的元素位置。若是找不到那樣的元素則返回npos。
find_last_not_of():在一個目標串中進行查找,返回下標值最大的與指定字符組中任何字符都不匹配的元素的位置。若找不到那樣的元素則返回npos。
rfind():對一個串從尾至頭查找一個指定的單個字符或字符組。若是找到,就返回首次匹配的開始位置;若是沒有查找到匹配的內容,則返回npos。

find(string, int):第一個參數用來指示要查找的字符,第二個參數用來表示從字符串的何處開始查找子串(默認的查找位置是0)。

舉例:字符串匹配ios

 1 #include "stdafx.h"
 2 #include<iostream>
 3 #include<math.h>
 4 #include<string>
 5 using namespace std;
 6 
 7 int _tmain(int argc, _TCHAR* argv[])
 8 {
 9 string T;//原串
10 string P;//模式
11 while(cin>>T>>P)
12 { 
13 int count=0;
14 int begin=-1;
15 while((begin=T.find(P,begin+1))!=string::npos)
16 {
17 count++;
18 }
19 cout<<count<<endl;
20 }
21 int z;
22 cin>>z;
23 return 0;
24 }

轉載請標明出處:http://www.cnblogs.com/fnlingnzb-learner/p/5831454.html數組

相關文章
相關標籤/搜索