vector
//初始化
vector<int> a;
vector<int> a(n);
vector<int> a[n];
vector<int> a(n, 0);//长度为n,值为0
size() //返回元素个数
empty() //返回是否为空
clear() //清空
front()/back() //返回第一个/最后一个元素
push_back()/pop_back() //在尾端插入元素/删除元素
begin()/end() //迭代器
[] //随机访问
for(int i = 0; i < a.size(); ++ i)
for(vector<int>::iterator/*auto*/ i = a.begin(); i != a.end(); ++ i)
for(auto x : a)
pair
pair<T, T> p;
pair<T, pair<T, T>> p;
p = make_pair(a, b);
p = {a, b};
p.first/p.second //第一个元素/第二个元素
- 黑科技:
- 也支持比较运算
- 以first为第一关键字,以second为第二关键字
string
string a = "adfb";
a += "adf";
a += 'c';
size()/length() //返回字符串长度
empty() //返回是否为空
clear() //清空
substr() //求子串
a.substr(st, len) //从下标st开始长度为len的子串
a.substr(st) //从st开始到结尾的子串
c_str() //返回字符串地址
//printf()无法输出string,但是可以printf("%s", a.c_str);
queue
- queue
size()
empty()
push() //想队尾插入元素
pop() //弹出队头元素
front() //返回队头元素
back() //返回队尾元素
//队列没有clear()函数
- priority_queue
priority_queue<int> heap; //堆默认为大根堆
heap.push(-x); //将数反号实现小根堆
priority_queue<int, vector<int>, greater<int> > heap //直接定义小根堆
push() //插入一个元素
top() //返回堆顶元素
pop() //弹出堆顶元素
stack
size()
empty()
push() //向栈顶插入元素
top() //返回栈顶元素
pop() //弹出栈顶元素
deque
size()
empty()
clear()
front()
back()
push_back()/pop_back()
push_front()/pop_front()
begin()/end()
[]
//操作多效率低
set
map
bitset
- 压位
- bool 类型位一个字节,8位
- 如:压位将bool 占用内存压缩1/8,使bool类型只占一个二进制位
- bitset 相当于一个二进制数组,数组里存0/1,一个数组元素占1个二进制位
- 初始化:
bitset<10000> s;
~, &, |, ^
>>, <<
==, !=
[]
count() //返回有多少1
any() //判断是否至少有一个1
none() //判断是否全为0
set() //把所有位置成1
set(k, v) //将第k位变成v
reset() //把所有位变成0
flip() //等价于~
flip(k) //把第k位取反