C++ Primer笔记7_STL之关联容器

C++ Primer笔记7_STL之关联容器

大家好,又见面了,我是全栈君。

关联容器

与顺序容器不同,关联容器的元素是按keyword来訪问和保存的。而顺序容器中的元素是按他们在容器中的位置来顺序保存的。

关联容器最常见的是map、set、multimap、multiset

map的元素以键值【key-value】对的形式组织:键用作元素在map中的索引,而值则表示所存储和读取的数据。

set仅包括一个键。并有效的支持关于某个键是否存在的查询。

pair类型

首先介绍下pair,pair定义在utility头文件里,一个pair保存两个数据成员,类似容器,pair是一个用来生成特点类型的模板。

当创建一个pair时,我们必须提供两个类型名。

pair<string, string> a; //保存两个string

pair<string, int> b; //一个保存string,一个保存int

能够使用make_pair来构建一个pair

#include <iostream>
#include <utility>

using namespace std;

int main()
{
	typedef pair<string, size_t> PS;
	PS p("hello", 10);//等价于pair<string, size_t> p("hello", 10);

	PS p1 = make_pair("SCOTT", 20);//make_pair(v1, v2); 以v1、v2来构建一个pair

	cout << p.first << endl;
	cout << p.second << endl;

	cout << p1.first << endl;
	cout << p1.second << endl;
	
	return 0;
}

map对象

定义map对象:

map<string, int> p;//定义一个空map

map<K, V>m;//——创建一个名为m的空对象,键和值类型分别为K和V
map<K, V>m(m2);//——m是m2的副本。注意K和V的值要同样
map<K, V>m(b,e);//——创建map类型的对象m,存储迭代器b和e标记的范围内全部元素的副本。


关联容器操作:


key_type——此容器类型的keyword类型

mapped_type——每一个keyword关联的类型;仅仅适用于map

value_type——对于set。与key_value同样。对于map。为pair类型:pair<const key_type, mapped_type>

#include <iostream>
#include <map>
using namespace std;

int main()
{
	map<string, int> p;
	p.insert(make_pair("Hello", 20));
	map<string, int>::iterator i = p.begin();

	map<string, int>::key_type first = i->first;//map对象自己定义了key_type与mapped_type两个类型
	map<string, int>::mapped_type second = i->second;

	cout << first << endl;
	cout << second << endl;

	while(i!=p.end())
	{
		cout << i->first << " " << i->second << endl;
		++i;
	}

	

	return 0;
}


给map加入元素:

    1、能够使用insert成员实现;

    2、或者先通过下标操作符获取元素,然后给获取的元素赋值。

   使用下标訪问map与使用下标訪问数组或vector的行为截然不同用下标訪问不存在的元素将导致在map容器中加入一个新元素,它的键即为该下标值


查找与统计map中的元素:

    1、使用m.count(k); 统计m中k出现的次数

    2、使用m.find(k);查找以k为索引的元素。假设存在返回指向该元素的迭代器,否则返回末端迭代器


统计单词出现的次数:

#include <iostream>
#include <map>

using namespace std;

int main()
{
	string s;
	map<string, int> wordCnt;
	map<string, int>::iterator i;

	while(cin >> s)
	{
		wordCnt[s]++;
	}
	
	for(i = wordCnt.begin(); i!=wordCnt.end(); ++i)
	{
		cout << i->first << " " << i->second << endl;
	}


	return 0;
}

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/116520.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 【STM32】UART和USART的区别[通俗易懂]

    【STM32】UART和USART的区别[通俗易懂]1、UART:universalasynchronousreceiverandtransmitter通用异步收发器;2、USART:universalsynchronousasynchronousreceiverandtransmitter通用同步异步收发器。1、通用异步收发器:通用异步收发器是一种通用串行数据总线,用于异步通信。该总线双向通信,可以实现全双工传…

    2022年5月19日
    38
  • linux中iostat命令_linux运维和网络运维

    linux中iostat命令_linux运维和网络运维Linux系统中的iostat是I/Ostatistics(输入/输出统计)的缩写,iostat工具将对系统的磁盘操作活动进行监视。它的特点是汇报磁盘活动统计情况,同时也会汇报出CPU使用情况。同vmstat一样,iostat也有一个弱点,就是它不能对某个进程进行深入分析,仅对系统的整体情况进行分析。……………

    2022年10月6日
    0
  • Java面经5

    创建索引的注意事项并不是创建的索引越多越好,索引对于查询能进行加速,但对于插入、删除和更新,由于需要对索引进行创建与维护,会影响了这三个操作的速度且索引占用空间创建索引一般创建在主键上、需要频繁使用的条件字段上、范围查找对于多值索引满足最左前缀字段秒杀系统秒杀获得开始之前:将静态网页资源放到反向代理上进行缓存,避免所有的请求达到服务器。将活动信息、开始信息、能否进行秒杀活动信…

    2022年4月7日
    33
  • 如何修改Tomcat版本[通俗易懂]

    如何修改Tomcat版本[通俗易懂]1.找到tomcat所在位置进入lib目录apache-tomcat-8.0.0\lib2.lib目录下有个catalina.jar用解压缩软件打开(可以先解压再修改版本号再打成jar包这样太麻烦所以直接用解压缩软件打开就行,我用的是winzip)3.打开后在catalina.jar\org\apache\catalin

    2022年8月30日
    0
  • A左右ndroid正在使用Uri监视数据库中的更改

    A左右ndroid正在使用Uri监视数据库中的更改

    2022年1月13日
    40
  • 跟版网 > 织梦教程 > 织梦安装使用 > 织梦DedeCMS附件上传大

    跟版网 > 织梦教程 > 织梦安装使用 > 织梦DedeCMS附件上传大

    2021年9月25日
    35

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号