在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
1 ////find函数返回类型 size_type 2 string s("1a2b3c4d5e6f7g8h9i1a2b3c4d5e6f7g8ha9i"); 3 string flag; 4 string::size_type position; 5 6 //find 函数 返回jk 在s 中的下标位置 7 position = s.find("jk"); 8 if (position != s.npos) //如果没找到,返回一个特别的标志c++中用npos表示,我这里npos取值是4294967295, 9 { 10 cout << "position is : " << position << endl; 11 } 12 else 13 { 14 cout << "Not found the flag" + flag; 15 } 16 17 18 //find 函数 返回flag 中任意字符 在s 中第一次出现的下标位置 19 flag = "c"; 20 position = s.find_first_of(flag); 21 cout << "s.find_first_of(flag) is : " << position << endl; 22 23 //从字符串s 下标5开始,查找字符串b ,返回b 在s 中的下标 24 position=s.find("b",5); 25 cout<<"s.find(b,5) is : "<<position<<endl; 26 27 //查找s 中flag 出现的所有位置。 28 flag="a"; 29 position=0; 30 int i=1; 31 while((position=s.find_first_of(flag,position))!=string::npos) 32 { 33 //position=s.find_first_of(flag,position); 34 cout<<"position "<<i<<" : "<<position<<endl; 35 position++; 36 i++; 37 } 38 39 //查找flag 中与s 第一个不匹配的位置 40 flag="acb12389efgxyz789"; 41 position=flag.find_first_not_of (s); 42 cout<<"flag.find_first_not_of (s) :"<<position<<endl; 43 44 45 //反向查找,flag 在s 中最后出现的位置 46 flag="3"; 47 position=s.rfind (flag); 48 cout<<"s.rfind (flag) :"<<position<<endl; 49 } 在写C++程序中,总会遇到要从一个字符串中查找一小段子字符串的情况,对于在C中,我们经常用到strstr()或者strchr()这两种方法。而对于C++的string,我们往往会用到find()。 find():在一个字符串中查找一个指定的单个字符或字符数组。如果找到,就返回首次匹配的开始位置;如果没有查找到匹配的内容,就返回string::npos。 find_first_of():在一个目标串中进行查找,返回值是第一个与指定字符组中任何字符匹配的字符位置。如果没有查找到匹配的内容,则返回npos。 find_last_of():在一个目标串中进行查找,返回最后一个与指定字符组中任何字符匹配的字符位置。如果没有查找到匹配的内容,则返回npos
|
2023-10-27
2022-08-15
2022-08-17
2022-09-23
2022-08-13
请发表评论