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)
上一篇 2022年1月20日 上午9:00
下一篇 2022年1月20日 上午10:00


相关推荐

  • tinyint 范围 mysql_mysql中TINYINT的取值范围

    tinyint 范围 mysql_mysql中TINYINT的取值范围在 MySQL 的数据类型中 Tinyint 的取值范围是 带符号的范围是 128 到 127 无符号的范围是 0 到 255 见官方 MySQL5 1 参考手册 http dev mysql com doc refman 5 1 zh column types html numeric types Tinyint 占用 1 字节的存储空间 即 8 位 bit 那么 Tinyint 的取值范围怎么来的呢 我们先看无符号

    2026年3月17日
    2
  • hystrix实现服务降级的3种方式[通俗易懂]

    hystrix实现服务降级的3种方式[通俗易懂]1、hystrix是什么Hystrix是一款开源的容错插件,具有依赖隔离,系统容错降级等功能,这也是其最重要的两种用途,还有请求合并等功能2、为什么要进行隔离在实际工作中,尤其是分布式、微服务越来越普遍的今天,一个服务经常需要调用其他的服务,即RPC调用,而调用最多的方式还是通过http请求进行调用,这里面就有一个问题了,如果调用过程中,因为网络等原因,造成某个服务调用超时,如果没有熔断机制…

    2022年4月30日
    127
  • Pycharm中更改镜像源

    Pycharm中更改镜像源镜像网站是将一个完全相同的站点放到几个服务器 分别有自己的 URL 在这些服务器上互为镜像网站 它和主站并没有太大差别 或者可算是为主站作的后备措施 有了镜像网站的好处是 如果不能对主站作正常访问 如某个服务器死掉或出了意外 但仍能通过其它服务器正常浏览 相对来说主站在速度等各方面比镜像站点略胜一筹

    2026年3月27日
    2
  • 解决virtualbox虚拟机桥接模式下不能上网

    解决virtualbox虚拟机桥接模式下不能上网virtualbox虚拟机桥接模式下不能上网欢迎使用Markdown编辑器欢迎使用Markdown编辑器https://blog.csdn.net/wild46cat/article/details/53100931跟着这个链接操作在主机上设置好网络然后在虚拟机上设置,也是跟着其他作者教程做的,一时找不到那个网页了vim/etc/resolv.confvim/etc/network/interfaces/…

    2022年6月10日
    67
  • Agent智能体和workflow工作流是一回事吗?如果不是那么它们的区别是什么?

    Agent智能体和workflow工作流是一回事吗?如果不是那么它们的区别是什么?

    2026年3月16日
    2
  • 【Claude Code】 保姆级教程

    【Claude Code】 保姆级教程

    2026年3月16日
    2

发表回复

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

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