标签: 容器

C++高级_Map/multimap容器_STL标准模板库

Map容器的简介 map是标准的关联式容器,一个map是一个兼职对序列,即(key,value)对。他提供基于key的快速检索能力 map中key值是唯一的,集合中得元素按一定的顺序排列,元素插入过程是按照排序规则插入,所以不能指定插入位置。 map的集体实现采用红黑树变体的 平衡二叉树 的数据结构,在插入操作和删除操作上比 vector 快。 mao可以直接存取key所对应的value,支持 [ ] 操作符,例如:map[key] = valie。 multimap与map的区别:map支持唯一键值,每个键只能出现一次。 而multimao中相同键可以出现多次。 multimap不支持 [ …

C++高级_pair对组的使用_STL标准模板库

pair对组的使用 pair译为对组,可以将两个值视为一个单元 将两个值使用为一个单元的情况,就可以使用pairs。在c++的标准模板库中,很多模板容器的实现都使用了pairs,例如:map、mutimap等键值对组合结构。 类模板:template <class T1, class T2> struct pair 参数:T1是第一个值的数据类型,T2是第二个值的数据类型。 功能:pair将一对值组合成一个值,这一对值可以具有不同的数据类型(T1和T2),两个值可以分别用pair的两个公有函数first和second访问。 pair.first 是pair里面的第一个值,是T1类型…

C++高级_Set/multiset容器_STL标准模板库

set是一个集合容器u其中所包含的元素是唯一的u集合中的元素按一定的 顺序排列。元素插入过程是按排序规则插入,所以不能指定插入位置。 set采用“黑树变体的数据…构实现,“黑树属于平衡二叉树。在插入操作 和删除操作上比vector快。 set不可以直接存取元素(不可以使用 at.(pos) 与 [ ] 操作符)。 multiset与set的区别:set支持唯一键值,每个元素值只能出现一次; 而multiset中同一只可以出现多次。 不可以直接修改set 或 multiset容器中得元素值,因为该类容器是自动排序的。如果希望修改一个元素值,必须先删除原来的元素,再插入先的元素。 使用…

C++高级_Queue容器_STL标准模板库

Queue容器的简介 queue是队列容器,是一个“先进先出”的容器。 queue是简单的装饰deque容器而成为另外的一种容器。 需要添加头文件:#include <queue> queue 与stack 模板类很相似,queue 模板类也需要两个模板参数,一个是元素类型,一个容器类 型,元素类型是必要的,容器类型是可选的,默认为deque 类型。 queue队列也是一个线性存储表,与后进先出的堆栈不同,元素数据在表的一端插入,在另一端进行删除,即构成了先进先出FIFO表。插入的一端成为队尾,删除的一端成为队首。 C++ STL对queue队列的泛化,是通过模板类型,将默认的de…

C++高级_Stack容器_STL标准模板库

Stack容器是什么? stack是堆栈容器,是一种“先进后出”的容器。 stack是简单地装饰deque容器而成为另外的一种容器。 使用的时候需要添加头文件: #include <stack> Stack(堆栈) 是一个容器类的改编,为程序员提供了堆栈的全部功能,— 也就是说实现了一个先进后出(FILO)的数据结构 Stack的默认构造:

stack的拷贝构造和赋值:

stack的push() 与 pop() 方法: [crayon-6075a28e…