STL是c++的标准模板库,模板分为类模板和函数模板,我们所说的容器是构成STL标准模板库的一部分,STL容器大致上分为两大部分:序列容器和相联容器,而相联容器又分为两大部分:排序容器和哈希容器
序列容器里面都可用放什么东西?例如存放int double float char 类型的元素,除此之外还可以存放自己定义的结构体元素。
1、vector动态数组:它的长度是可以改变的,在尾部插入和删除元素的时间复杂度为o(1),支持随机访问,(其实就是数组的升级版),但是在中间某个位置插入和删除元素时间复杂度为o(n),为什么?就算它支持随机访问,能快速找到要插入和删除的位置,但是插入或者删除后要进行元素的移动。
vector<int>a(20)//定义一个vector a容量为20
vector.push_back(1)//把1插入到尾部
vector.pop_back()//删除尾部元素
//insert函数需要借助迭代器实现在中间插入一个或者多个元素
//erase函数需要借助迭代器实现在中间删除一个或多个元素
2、deque双端队列容器:它在首位插入和删除元素的时间复杂度都是O(1),在中间插入和删除的时间复杂度和vector一样,支持随机访问。
3、list双向链表容器:不支持随机访问,但是在任意位置上插入和删除的时间复杂度都是O(1)。
相联容器里面存放的是啥?不像序列容器,相联容器顾名思义就是存放的是一个个存在联系的键值对,并且默认根据键的大小升序排序。
1、map映射容器的特点:map容器存储的各个键值对,既不能重复,也不能被修改,键的类型会用const修饰。
2、set容器的特点:使用 set 容器存储的各个键值对,要求键 key 和值 value 必须相等。
加油加油