C++容器学习

C++中有两种类型的容器:顺序容器关联容器。顺序容器主要有vectorlistdeque等。其中vector表示一段连续的内存,基于数组实现,list表示非连续的内存,基于链表实现,deque与vector类似,但是对首元素提供插入和删除的双向支持。关联容器主要有mapset。map是key-value形式,set是单值。map和set只能存放唯一的key,multimap和multiset可以存放多个相同的key。

容器类自动申请和释放内存,因此无需new和delete操作。


一、vector

vector基于模板实现,需包含头文件vector。实现机制类似数组.

用于快速查找,与尾部插入


二、list

List是stl实现的双向链表,与 向量(vectors)相比, 它允许快速的插入和删除,但是随机访问却比较慢。需要添加头文件list


三、deque

deque容器类与vector类似,支持随机访问和快速插入删除,它在容器中某一位置上的操作所花费的是线性时间。与vector不同的是,deque还支持从开始端插入数据:push_front()。其余类似vector操作方法的使用。


四、map

C++中map容器提供一个键值对(key/value)容器,map与multimap差别仅仅在于multiple允许一个键对应多个值。需要包含头文件map。对于迭代器来说,可以修改实值,而不能修改keyMap会根据key自动排序。

 multimap 与 map 一样,都是使用红黑树对记录型的元素数据,按元素键值的比较关系,进行快速的插入、删除和检索操作,所不同的是 multimap 允许将具有重复键值的元素插入容器。在 multimap 容器中,元素的键值与元素的映照数据的映照关系,是多对多的,因此,multimap 称为多重映照容器。multimap 与 map 之间的多重特性差异,类似于 multiset 与 set 的多重特性差异。

遍历 multimap 容器元素
/*    不同于 map 容器,multimap 容器只能采用迭代器的方式,而不能用数组方式,遍历容器的元素。迭代器方式的元素访问,一般要用 begin 和 end 函数找出遍历开始的首元素和结束元素,然后通过迭代器的 “++” 和 “*“ 操作取出元素。
    下面的示例程序,将水果价格元素表的记录打印出来。由于水果价格作为元素的键值,并采用默认的 less 作比较函数对象,将按价格由小到大打印出来。
*/

-------------------------------------------------------- 遍历 multimap 容器元素
#pragma warning(disable:4786)
#include 
#include 
using namespace std;
int main()
{
    multimap mm;
    mm.insert(pair(3.0f, "apple"));
    mm.insert(pair(3.0f, "pear"));
    mm.insert(pair(2.6f, "orange"));
    mm.insert(pair(1.8f, "banana"));
    mm.insert(pair(6.3f, "lichee"));
    // 遍历打印
    multimap::iterator  i, iend;
    iend = mm.end();
    for (i=mm.begin(); i!=iend; ++i)
        cout << (*i).second << '    ' << (*i).first << "元/斤 \n";

    return 0;
}


 
  

五、set

set的含义是集合,它是一个有序的容器,里面的元素都是排序好的,支持插入,删除,查找等操作,就像一个集合一样。所有的操作的都是严格在logn时间之内完成,效率非常高。set和multiset的区别是:set插入的元素不能相同,但是multiset可以相同。Set默认自动排序。使用方法类似list。

set集合容器:实现了红黑树的平衡二叉检索树的数据结构,插入元素时,它会自动调整二叉树的排列,把元素放到适当的位置,以保证每个子树根节点键值大于左子树所有节点的键值,小于右子树所有节点的键值;另外,还得保证根节点左子树的高度与右子树高度相等。
平衡二叉检索树使用中序遍历算法,检索效率高于vector、deque和list等容器,另外使用中序遍历可将键值按照从小到大遍历出来。
构造set集合主要目的是为了快速检索,不可直接去修改键值。multiset与set功能相同,只不过它允许值重复

#include 
#include 

using namespace std;

int main()
{
    set s;
    s.insert(1);
    s.insert(2);
    s.insert(3);
    s.insert(1);
    cout<<"set 的 size 值为 :"<



你可能感兴趣的:(C++)