转载自:https://blog.youkuaiyun.com/zy47675676/article/details/89466873
1、substr()的使用:
string str.substr(nStart) //默认 从str字符串nStart位置开始截取到str结束为止
string str.substr(nStart, nLength) // 从str字符串nStart位置开始截取nLength个字符!如果nLength>剩余的字符则截取到str结束为止
举例:
string str("12345asdf");
string strTmp1= str.substr(1); //获得字符串str中 从第1位开始到结束的字符串,strTmp1值为:"23456asdf"
string strTmp2 = str.substr(1,5); //获得字符串s中 从第1位开始的长度为5的字符串,strTmp1值为:"23456"
2、erase()的使用
erase函数的原型如下:
(1)string& erase ( size_t pos = 0, size_t n = npos );
(2)iterator erase ( iterator position );
(3)iterator erase ( iterator first, iterator last );
也就是说有三种用法:
(1)erase(pos,n); 删除从pos开始的n个字符,比如erase(0,1)就是删除第一个字符
(2)erase(position);删除position处的一个字符(position是个string类型的迭代器)
(3)erase(first,last);删除从first到last之间的字符(first和last都是迭代器)
//普通位置删除
string str("0123456789");
str.erase(3);//从3开始到最后
cout << str << endl;//012
string str1("0123456789");
str1.erase(3,5);//从3开始删除五个元素,34567
cout << str1 << endl;//01289
//迭代器位置删除
string str2("0123456789");
str2.erase(str2.begin() + 3);//删除位置3的元素
cout << str2 << endl;//012456789
string str3("0123456789");
str3.erase(str3.begin() + 3,str3.end());//删除位置3到末尾的元素(尾后迭代器之前)
cout << str3 << endl;//012
//【值得注意】
string str4("0123456789");
//返回指向删除范围后一个元素的迭代器
auto it = str4.erase(str4.begin() + 3, str4.begin() + 8);//删除位置3到位置8之前(3-7)的元素,而并非3-8
cout << str4 << endl;//01289
it = str4.erase(it);//返回删除元素后一个元素的迭代器
cout << str4 << endl;//0129
str4.erase(it);
cout << str4 << endl;//012
3、find()的使用 :
#include<iostream>
#include<string>
using namespace std;
int main()
{
string st1=("babbabab");
//从前面找a的位置
cout<<st1.find('a')<<" "; cout<<"输出第一个a的下标 (从0开始) "<<endl;
cout<<st1.find('a',0)<<" ";cout<<"('a',x) 从x下标开始查询a的下标"<<endl;
//从后面找a 的位置
cout<<st1.rfind('a',1)<<" ";cout<<"从0 到 x 从后向前查找a 所在该串的位置"<<endl;
cout<<(st1.find('c',0)==str1,npos)<<endl;
cout<<(st1.find('c',0)==-1)<<endl; //该数字不存在 就满足条件 为真 1 两句均输出1,原因是计算机中-1和4294967295都表示为32个1(二进制)
//st1.find("y",x); 该y可以是字符串 字符 string char型 均可
cout<<st1.find("bababa",0,4)<<endl; //6 第三个参数不得超过第一个参数
return 0;
}
补充:
3、STL中的find
std::find()
用法:find(first, end, value);
返回区间[first,end)中第一个值等于value的元素位置;若未找到,返回end。函数返回的是迭代器或指针,即位置信息。
参考代码main(),查找findvalue的值
i
nt main()
{
vector<int> vec;
int findvalue=11;
for (int i=1;i<11;i++)
{
vec.push_back(i);
}
vector<int>::iterator vec_it;
vec_it=find(vec.begin(),vec.end(),findvalue);
if (vec_it!=vec.end())
{
cout<<findvalue<<" position is "<<distance(vec.begin(),vec_it)<<endl;
}
else
cout<<findvalue<<"is not found"<<endl;
return 0;
}