MrFuWen 2020-06-25
set模板类在头文件 中使用前需要先引入头文件。
set集合容器实现了红黑树(Red-Black Tree)的平衡二叉检索树的数据结构,在插入元素时,它会自动调整二叉树的排列,把该元素放到适当的位置,以确保每个树根节点的键值大于左子树所有节点的键值,而小于右子树所有节点的键值;另外,还确保根节点左子树的高度与右子树的高度相等,这样,二叉树的高度最小,从而检索速度最快。要注意的是,它不会重复插入相同键值的元素,而采取忽略处理。
s.begin() // 返回指向第一个元素的迭代器 s.clear() // 清除所有元素 s.count() // 返回某个值元素的个数 s.empty() // 如果集合为空,返回true(真) s.end() // 返回指向最后一个元素之后的迭代器,不是最后一个元素 s.equal_range() // 返回集合中与给定值相等的上下限的两个迭代器 s.erase() // 删除集合中的元素 s.find() // 返回一个指向被查找到元素的迭代器 s.get_allocator() // 返回集合的分配器 s.insert() // 在集合中插入元素 s.lower_bound() // 返回指向大于(或等于)某值的第一个元素的迭代器 s.key_comp() // 返回一个用于元素间值比较的函数 s.max_size() // 返回集合能容纳的元素的最大限值 s.rbegin() // 返回指向集合中最后一个元素的反向迭代器 s.rend() // 返回指向集合中第一个元素的反向迭代器 s.size() // 集合中元素的数目 s.swap() // 交换两个集合变量 s.upper_bound() // 返回大于某个值元素的迭代器 s.value_comp() // 返回一个用于比较元素间的值的函数
set<type> 容器名称 例如: 1. 未初始化大小 set<int> s; 2. 初始化大小 set<int> s(n); set<int> s; s.resize(n); // n 表示所申请的大小
#include <iostream> #include <set> using namespace std; set<int> s; int main() { s.insert(1); s.insert(2); s.insert(3); }
有两种方法
使用auto关键字获取迭代器
创建set::iterator it;
#include <iostream> #include <set> #include <vector> using namespace std; set<int> s; int main() { for(int i = 0;i < 10;i ++) s.insert(i); // 第一种方式 for(auto it = s.begin() ; it != s.end() ;it ++){ printf("%d ", *it); } cout << endl; // 第二种方式 set<int>::iterator it; for(it = s.begin() ; it != s.end() ; it++){ cout << *it << " "; } return 0; }
输出结果
0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9
查找元素的方法和返回类型经常会用到需要熟记!
find() 方法查找指定的元素并返回,查找值的迭代器。
如果没有找到则会返回end()!!
#include <iostream> #include <set> #include <vector> using namespace std; set<int> s; int main() { for(int i = 0;i < 10;i ++) s.insert(i); // 第一种方式 for(auto it = s.begin() ; it != s.end() ;it ++){ printf("%d ", *it); } cout << endl; // 第二种方式 set<int>::iterator it; for(it = s.begin() ; it != s.end() ; it++){ cout << *it << " "; } if(s.find(5) != s.end()){ printf("找到该元素\n"); } return 0; }
erase()方法删除集合中的指定元素
#include <iostream> #include <set> #include <vector> using namespace std; set<int> s; int main() { for(int i = 0;i < 10;i ++) s.insert(i); // 第一种方式 for(auto it = s.begin() ; it != s.end() ;it ++){ printf("%d ", *it); } cout << endl; // 第二种方式 set<int>::iterator it; for(it = s.begin() ; it != s.end() ; it++){ cout << *it << " "; } if(s.find(5) != s.end()) { printf("find\n"); } s.erase(5); for(auto it = s.begin() ; it != s.end() ;it ++){ printf("%d ", *it); } return 0; }
https://blog.csdn.net/love20165104027/article/details/81510406