STL
set 容器
定义
#include<set>
set <int>s[n];
用法
s.begin() //指向第一个元素的迭代器
s.end() //指向最后一个元素的迭代器
s.size() //去重之后还有几个元素
s.clear() //清除set里的所有元素
s.insert() //输入元素
s.erase() //删去元素
d.insert(s.begin(),s.end() ) //将两个容器合并
s.count() //输出某个元素的个数
s.empty() //判断是否为空
输出
迭代器输出
for(auto i=s.begin();i!=s.end();i++)
cout<<*i;
deque容器
定义
#include<deque>
deque<int>s;
用法
s.empty() //判断是否为空
s.size() //容器大小
s.push_back() //在容器尾部插入一个数据
s.push_front() //在容器开头插入一个数据
s.pop_back() //在容器尾部删去一个数据
s.pop_front() //在容器开头插入一个数据
s.insert(a,b) //在a处插入b
s.insert(a,n,b) //在a处插入n个b
s.clear() //清除所有元素
s.erase() //删除该位置的元素
s.erase(a,b) //删除从 a到b的所有元素
输出
输出与set相同
vector 容器
函数
vector(v.begin(),v.end())//将[v.begin(),v.end()]区间中的元素拷贝给本身
vextor(n,elem)//将n个elem拷贝给本身
vector(const vector &v ) //拷贝构造函数
用法
s.empty() //是否为空
s.size() //容器大小
s.push_back(n)//尾部插入n
s.pop_back()//删除最后一个元素
s.insert(pop,n,s)//在pop处插入n 个s
s.erase(pop)//删除pop处的元素
s.clear()//清除所有元素
s.at(i)//第i个元素为
s.front()//第一个元素为
s.back()//最后一个元素
函数
nth_element
用法
nth_element(a+1,a+1+k,a+1+n);
可以将第k个数放在第k位
队列queue
函数
q.empty()//判断是否为空
q.size()//返回队列中元素个数
q.pop()//删除队列首元素
q.front()//查找队首的元素
q.push()//在队尾插入新元素
q.back()//返回队列尾的值
pair<int, int>
first, 第一个元素
second, 第二个元素
支持比较运算,以first为第一关键字,以second为第二关键字(字典序)
string,字符串
size()/length() 返回字符串长度
empty()
clear()
substr(起始下标,(子串长度)) 返回子串
c_str() 返回字符串所在字符数组的起始地址
queue, 队列
size()
empty()
push() 向队尾插入一个元素
front() 返回队头元素
back() 返回队尾元素
pop() 弹出队头元素
priority_queue, 优先队列,默认是大根堆
push() 插入一个元素
top() 返回堆顶元素
pop() 弹出堆顶元素
定义成小根堆的方式:priority_queue<int, vector<int>, greater<int>> q;
stack, 栈
size()
empty()
push() 向栈顶插入一个元素
top() 返回栈顶元素
pop() 弹出栈顶元素
set, map, multiset, multimap, 基于平衡二叉树(红黑树),动态维护有序序列
size()
empty()
clear()
begin()/end()
++, -- 返回前驱和后继,时间复杂度 O(logn)
set/multiset
insert() 插入一个数
find() 查找一个数
count() 返回某一个数的个数
erase()
(1) 输入是一个数x,删除所有x O(k + logn)
(2) 输入一个迭代器,删除这个迭代器
lower_bound()/upper_bound()
lower_bound(x) 返回大于等于x的最小的数的迭代器
upper_bound(x) 返回大于x的最小的数的迭代器
map/multimap
insert() 插入的数是一个pair
erase() 输入的参数是pair或者迭代器
find()
[] 注意multimap不支持此操作。 时间复杂度是 O(logn)
lower_bound()/upper_bound()
unordered_set, unordered_map, unordered_multiset, unordered_multimap, 哈希表
和上面类似,增删改查的时间复杂度是 O(1)
不支持 lower_bound()/upper_bound(), 迭代器的++,--
bitset, 圧位
bitset<10000> s;
~, &, |, ^
>>, <<
==, !=
[]
count() 返回有多少个1
any() 判断是否至少有一个1
none() 判断是否全为0
set() 把所有位置成1
set(k, v) 将第k位变成v
reset() 把所有位变成0
flip() 等价于~
flip(k) 把第k位取反