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位取反
posted @ 2022-07-13 19:27  zyzzzzlh  阅读(33)  评论(0)    收藏  举报