标签: STL

C++高级_STL常用的拷贝和替换算法详解

常用的拷贝和替换算法: copy();                         复制序列 copy_backward();        与copy相同,不过元素是以相反顺序被拷贝。 replace();                     将指定范围内所有等于 old_value 的元素都用  新的值 代替。 replace_if();                 将指定范围内所有操作结果为true的元素用新值代替。 swap();             …

C++高级_STL常用的查找算法详解

常用的查找算法 adjacent_find:      在iterator对标识元素范围内,查找一对相邻重复元素,找到则返回指向这对元素的第一个元素的迭代器,否则返回 end()。重载版本使用输入的二元操作符代替相等的判断。 binary_search:     在有序序列中查找value,找到返回true。重载的版本实用指定的比较函数对象或函数指针来判断相等。 count:                 利用等于操作符,把标志范围内的元素与输入值比较,返回相等元素个数。 …

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

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

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

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

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

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

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

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

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

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

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

Deque容器 deque是“double-ended queue”的缩写,和vector一样都是STL的容器,deque是双端数组,二vector是单端的。 deque在接口上合vector非常相似,在许多操作的地方可以直接替换。 deque可以随机存取元素(支持索引值直接存取,用[]操作符或 at() 方法) deque头部和尾部添加或者移除元素都非常快速,但是在中部安插元素或移除元素都比较耗时。 使用时需要添加头文件:#include <deque> deq…

C++高级,关于STL标准模板库

1.关于什么事STL就不在这里累述了,不了解的可以去百度一下 整个软件领域里,数十年来确实都在为了一个目标而奋斗—可复用性 从最早的面向过程的函数库,到面向对象的程序设计思想,到各种组件 技术(如:COM、EJB),到设计模式(design  pattern)等等。而STL也在 做着类似的事情,同时在它背后蕴涵着一种新的程序设计思想–泛型化设计 (generic  programming)。 STL的基本概念 STL的代码可以在广义上分为三类: container…