Set是STL库中的Map的简化版,只有map中的key没有value。
①头文件和定义:
set<string> Set; //Set是Map的简化版
②迭代器和遍历:
set<string>::iterator set_it; //迭代器遍历
for (set_it = Set.begin(); set_it != Set.end(); set_it++) {}
③修改数据: insert();
Set.insert({ "a" }); //insert返回一个pair类型,第一个是一个迭代器指向元素,第二个是一个bool值,插入成功返回true,已经存在返回false
vector<int> vec = { 2,4,6,8,10 }; //将另一个容器内的数据插入进来
Set.insert(vec.begin(), vec.end());
set<string>::iterator set_it2; //迭代器遍历
for (set_it2 = Set.begin(); set_it2 != Set.end(); set_it2++) { }
Set.insert({ 1,2,3,4,5,6,7 }); //因为是不分顺序的,所以怎么插入都可以
④查找数据: find和count
Set.find("a");//返回迭代器,指向key=='a'的元素,若没有此元素返回my_set.end();
Set.count("a");//返回关键字等于'a'的数量,对已set不允许重复关键字,返回值永远是0或
⑤删除数据:erase()
Set.erase("a"); //删除数据
⑥基础信息:
Set.size();//得到尺寸,为key的尺寸
Set.empty(); //空为1,非空为0
Set.clear(); //清空所有数据