标签: C++

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++高级_ 迭代器(iterator)的基本原理和使用方法

除了使用下标来访问vector对象的元素外,标准库还提供了另一种检测元素的方法:使用迭代器(iterator)迭代器就如同一个指针。迭代器就是指针的泛指,可以指向元素。事实上,C++的指针也是一种迭代器。但是,迭代器不仅仅是指针,因此你不能认为他们一定具有地址值。例如,一个数组索引,也可以认为是一种迭代器。 迭代器是一个“可遍历STL容器内全部或部分元素”的对象。  迭代器指出容器中的一个特定位置。  迭代器就如同一个指针。  迭代器提供对一个容器中的对象的访问方法,并…