在刷题的时候我总是会遇到许多关于字符串操作的题目,然而每次使用字符串相关的函数时总是会忘,这里给各位做一个小总结。
首先是基础的,不太需要记的
s.begin();
s.end();//不用多说吧,是不是看过就不会忘
字符串长度
string s;
s.size();
s.length();
//都是返回长度,大小的,个人感觉没太大的区别
字符串的提出都可以通过切片索引来得到,再就是添加,添加一般俩字符串直接相加+,一个加号就可以解决。什么append就很少用。
然后这里主要记俩个重要的函数:erase和insert,太容易记忘了
erase
s.erase();
//这里有俩种做法
s.erase(s.begin());//删除迭代器所在位子的字符
s.erase(7);//删除索引起以后的所有字符
s.erase(3,7);//从3开始的7个字符
intsert重要且易忘
string s;
s = "hello";
s.insert(3,4, "w");//是插入索引为3的值之前,插入4个wwww
cout << s << endl;//输出为helwwwwwlo
//也可以直接插入字符串const string 类型
然后就是查找find
string s;
s.find("so");
该函数会返回找到的字符串的位置的第一个索引,如果没找到就会返回string::npos,比较容易记。
哦,对了,还有一个在算法题里容易用到的函数
substr
string s;
s = "hello";
s = s.substr(2,1);//索引为2之后的一个字符
s = s.substr(1);//索引为1之后的所有字符
算法题里面常用的差不多这些。
还有就是在头文件<sstream>字符串流的使用了,相当于重新进了一个缓存区,
string s;
s = "hello world";
stringstream in;
in << s;
string a, b;
in >> a >> b;
cout << a << endl;
cout << b << endl;
输出结果是hello world(中间换行)