参考:http://www.weixueyuan.net/view/6404.html

总结:

  基本的关联式容器主要有:set、multiset、map和multimap,这四种容器可以分为两组:map和set。

  set可以理解为我们数学中的集合,它可以包含0个或多个不重复、不排序的数据,这些数据被称为键值。

  map也是一种集合,它同样可以包含0个或多个不排序的元素对,每一个元素对有一个键值和一个与键值相关联的值,在map中键值是不允许重复的。

  而multiset则是允许重复的集合,multimap则是允许有重复键值的map,因为multiset和multimap可以看做是set和map的扩展,因此我们将主要介绍set和map。

  对于set容器,insert被重载过,其调用方式有两种,但是无论以哪种方式进行调用,insert函数都能保证插入元素后set容器中不会出现重复的元素。

  find函数可以用于查找set容器中是否包含指定的键值,如果存在,则返回指向该键值的迭代器,如果不存在,则返回与end()函数相同的结果。

  map是一种关联式的列表,即将一个键值与一个值一一对应起来。

  键值在map中是不允许出现重复的,但是与键值对应的值value可以出现重复。如果键值出现相同,则以最后一次出现的作为结果。 

  map容器则需要通过itor->first访问键值,并用itor->second访问与键值对应的值。

--------------

基本的关联式容器主要有:set、multiset、map和multimap,这四种容器可以分为两组:map和set。

set可以理解为我们数学中的集合,它可以包含0个或多个不重复、不排序的数据,这些数据被称为键值map也是一种集合,它同样可以包含0个或多个不排序的元素对,每一个元素对有一个键值和一个与键值相关联的值,在map中键值是不允许重复的。而multiset则是允许重复的集合,multimap则是允许有重复键值的map,因为multiset和multimap可以看做是set和map的扩展,因此我们将主要介绍set和map。

例1:

#include <iostream>
#include <set>
using namespace std; int main()
{
set< int > s;
s.insert(s.begin(), );
s.insert();
s.insert(s.end(),);
s.insert();
s.insert();
s.insert();
s.insert();
s.insert();
set< int >::const_iterator itor;
for(itor = s.begin (); itor != s.end(); itor++)
cout<< *itor<<" ";
cout<< endl;
itor = s.find( );
if( itor == s.end() )
cout<< "NOT Found 2!" << endl;
else
cout<< "Found 2 in set!" << endl;
itor = s.find( );
if( itor == s.end() )
cout<< "NOT Found 5!" << endl;
else
cout<< "Found 5 in set!" << endl;
return ;
}

本例是set的一个示例,在主函数中我们先创建了一个set容器整型的示例s,之后就开始向容器中添加数据。对于set容器,insert被重载过,其调用方式有两种,我们既可以向前面序列式容器那样调用:

s.insert( s.begin(), );
s.insert( s.end(), );
也可以不指定插入位置,而直接插入元素:
s.insert(  );

但是无论以哪种方式进行调用,insert函数都能保证插入元素后set容器中不会出现重复的元素。

在插入一些元素之后,我们就定义了一个迭代器itor用于访问容器中的元素。访问的方法和序列式容器相同。

find函数可以用于查找set容器中是否包含指定的键值,如果存在,则返回指向该键值的迭代器,如果不存在,则返回与end()函数相同的结果。在例1中,我们分别查找了键值2和5是否存在于集合s中,因为s容器没有2元素,因此返回值等于s.end(),存在5元素,因此查找5元素时,函数返回结果不等于s.end()。

例2:

#include <iostream>
#include <map>
using namespace std; int main()
{
map< char, int > m;
m[ 'a' ] = ;
m[ 'b' ] = ;
m[ 'c' ] = ;
m[ 'd' ] = ;
m[ 'e' ] = ;
m[ 'f' ] = ;
m[ 'g' ] = ;
m[ 'h' ] = ;
m[ 'a' ] = ;
map< char, int >::iterator itor;
for(itor = m.begin(); itor != m.end(); itor++)
cout << itor->first << " -- " << itor->second <<endl;
return ;
}

本例是一个map容器的示例程序,map是一种关联式的列表,即将一个键值与一个值一一对应起来。我们直接来看主函数,主函数一开始定义了一个map容器示例m,“map< char, int > m;”语句中char表示键值的数据类型,int表示与键值对应的值的数据类型。我们用字符来作为键值,键值在map中是不允许出现重复的,但是与键值对应的值value可以出现重复,如本例中m[ 'a' ]和m[ 'e' ]相同。但是如果键值出现相同,则以最后一次出现的作为结果,例如本例中一开始“m[ 'a' ] = 1;”,在后面又出现“m[ 'a' ] = 0;”,此时不会有语法错误,这两句可以理解为“m[ 'a' ] = 1;”是给“m[ 'a' ]”赋初值,其值为1,而“m[ 'a' ] = 0;”则可以理解为我们将“m[ 'a' ]”的值由1修改为0。

遍历map时同样是使用迭代器,在函数中我们定义了一个迭代器itor,由于map中是由元素对组成的,包含两个元素,因此遍历方法与前面所介绍的容器稍有不同,前面的容器用*itor就可以直接获得所需要的元素,而map容器则需要通过itor->first访问键值,并用itor->second访问与键值对应的值。

例2最终运行结果如下:
a–– 0
b –– 2
c –– 3
d –– 4
e –– 1
f –– 2
g –– 3
h –– 4

7.7 C++基本关联式容器的更多相关文章

  1. STL源码分析读书笔记--第5章--关联式容器

    1.关联式容器的概念 上一篇文章讲序列式容器,序列式容器的概念与关联式容器相对,不提供按序索引.它分为set和map两大类,这两大类各自有各自的衍生体multiset和multimap,的底层机制都是 ...

  2. 关联式容器(associative containers)

    关联式容器(associative containers) 根据数据在容器中的排列特性,容器可分为序列式(sequence)和关联式(associative)两种. 标准的STL关联式容器分为set( ...

  3. Map(关联式容器)

    map是一类关联式容器,自动建立Key - Value的对应 , key 和 Value可以是任意你需要的类型.下面介绍 map 中一些常用的函数: 一.map 中的 begin 和 end 函数 m ...

  4. C++ 容器:顺序性容器、关联式容器和容器适配器

    什么是容器 首先,我们必须理解一下什么是容器,在C++ 中容器被定义为:在数据存储上,有一种对象类型,它可以持有其它对象或指向其它对像的指针,这种对象类型就叫做容器.很简单,容器就是保存其它对象的对象 ...

  5. STL——关联式容器

    一.关联式容器 标准的STL关联式容器分为set(集合)/map(映射表)两大类,以及这两大类的衍生体multiset(多键集合)和 multimap(多键映射表).这些容器的底层机制均以RB-tre ...

  6. STL学习笔记--关联式容器

    关联式容器依据特定的排序准则,自动为其元素排序.缺省情况下以operator<进行比较.set multiset map multimap是一种非线性的树结构,具体的说是采用一种比较高效的特殊平 ...

  7. C++关联式容器的排序准则

    stl中set和map为关联式容器,会根据排序准将元素自动排序.原型如下: template<class _Kty, class _Pr = less<_Kty>, class _A ...

  8. vector是序列式容器而set是关联式容器。set包含0个或多个不重复不排序的元素。

    1.vector是序列式容器而set是关联式容器.set包含0个或多个不重复不排序的元素.也就是说set能够保证它里面所有的元素都是不重复的.另外对set容器进行插入时可以指定插入位置或者不指定插入位 ...

  9. STL学习笔记(关联式容器)

    Set和Multisets set和multiset会根据特定的排序准则,自动将元素排序.两者不同在于multisets允许元素重复而set不允许. 1.set和multiset的操作函数 生成.复制 ...

随机推荐

  1. (转+整理)C# BinaryFormatter进行序列化与反序列化

    序列化又称串行化,是.NET运行时环境用来支持用户定义类型的流化的机制.其目的是以某种存储形式使自定义对象持久化,或者将这种对象从一个地方传输到另一个地方. .NET框架提供了两种种串行化的方式:1. ...

  2. echarts画多条一元回归线

    理论上两点一线,只要两个点即可 option = { title: { text: '', left: 'center' }, tooltip: { // trigger: 'item', // fo ...

  3. java---->lombok.jar的使用

    lombok.jar是在看一个项目的代码时遇见的一个“新包”,记录下用法: 1.新建maven工程myfirst,新建一个javabean User,写一个LombokTest类,在pom.xml引入 ...

  4. 彻底搞懂 CPU 中的内存结构

    https://www.cnblogs.com/YJK923/p/10302180.html

  5. Lab 1-3

    Lab 1-3 Analyze the file Lab01-03.exe. Questions and Short Answers Upload the Lab01-03.exe file to h ...

  6. LeetCode--283--移动0

    问题描述: 给定一个数组 nums,编写一个函数将所有 0 移动到数组的末尾,同时保持非零元素的相对顺序. 示例: 输入: [0,1,0,3,12] 输出: [1,3,12,0,0] 说明: 必须在原 ...

  7. uWSGI和Gunicorn

    因为nginx等优秀的开源项目,有不少本来不是做服务器的同学也可以写很多服务器端的程序了.但是在聊天中会发现,大家虽然写了不少代码,但是对wsgi是什么,gunicorn是什么,反向代理又是什么并不了 ...

  8. CentOS7 下源代码安装php7

    安装PHP7: php-7.1.2.tar.gz:下载:wget http://cn2.php.net/get/php-7.1.2.tar.gz/from/this/mirror 安装php: # t ...

  9. 笔记react router 4(二)

    上一篇我们提到react router 4的dom特性.那么这一次,我们来说一说4.X中的路由组件嵌套. 用过3.X的同学应该知道,路由组件的嵌套(即,路由的配置)方式是通过给<Route> ...

  10. c++中利用localtime_s函数格式化输出当地日期与时间

    Visual C++ 6.0开发环境中显示当地日期与时间主要通过localtime()函数来实现,该函数的原型在time.h头文件中,其语法格式如下: struct tm *localtime(xon ...