解释都在代码里,示例才是最好的老师
#include <string>
#include <vector>
#include <stack>
#include <list>
#include <set>
#include <iostream>
using namespace std;
int main()
{
string str = { "abcdef" }; vector<int> v = {1,2,3,4,5,6,};
stack<int>sta; for (int i = 0; i <=5; i++) { sta.push(i); }//输入用push,因为只能从一头输入
list<int>lis; for (int i = 0; i <=5; i++) { lis.push_back(i); }lis.push_front(0);//可以从两头输入
set<int> se; for (int i = 0; i <=5; i++) { se.insert(i); }//输入自动排序,所以就是插入 可遍历
//string类删除插入
str.erase(str.begin()+2);//传入指定迭代器
cout << str << endl;
str.insert(str.begin() + 2, 'c');//删除后的复原到原来位置
cout << str << endl;
str.erase(str.begin() + 1, str.end() - 2);//!!!end()迭代器是最后一位的下一位,所以end()-2是e,erase满足左闭右开[begin()+1,end()-2),所以不删除e
cout << str << endl;
int a = str.find('e');//find参数就是元素,返回下标数字对应看175行
cout << a << endl;;
//vector容器的删除与插入与string类似,参数是迭代器或者两个迭代器,两个迭代器满足左闭右开[ , )不会消除第二个迭代器对应的数字
v.erase(v.begin() + 1, v.end() - 2); for (auto& i : v) { cout << i; }
cout << endl;
int b = find(v.begin(), v.end(), 4)-v.begin();//find函数的参数为3个,返回迭代器,迭代器-迭代器返回下标数字
//对set
se.erase(3);//删除的参数就是那个元素,不是迭代器
for (auto& u : se)cout << u;
return 0;
}