STL(结)

news2025/1/12 3:44:31

STL(结)

  • map
    • 存储结构
    • 基本操作
      • equal_range
      • 遍历方式
    • 插入
  • multimap
  • set
  • unordered_map
  • map和无序map的异同
    • map
    • unordered_map

map

存储结构

map容器的底层存储是一个红黑树,遍历方式都是按照中序遍历的方式进行的。

int main() {
	std::map<int, std::string> ismap;
	ismap[12] = "yhping";
	ismap[34] = "xjq";
	ismap[23] = "hx";
	ismap[67] = "dxw";
	ismap[45] = "yx";
	ismap[56] = "dy";
}

上面代码,我们定义了一map容器,其中放置了数据,其存储结构是红黑树,按照关键码进行排序。如下图:
在这里插入图片描述
我们知道了其存储结构,才可以了解其成员方法。

基本操作

equal_range

函数声明:std::pair<const_iterator,const_iterator> equal_range(const k&x)const
该函数返回容器中所拥有给定关键的元素范围,其中键值对中存在两个迭代器,一个指向首个不小于key的元素,首个迭代器可以通过lower_bound()获得,而第二个迭代器指向首个大于key的元素,可换用upper_bound()获得。
试想 auto it= ismap.equal_range(40);该函数返回值的两个指针指向。
根据上面代码我们也可得到第一个迭代器指向45,第二个也指向45。

cout << it.first->first << " " << it.second->first << endl;

执行该语句得到的结果便是45,45。

	auto et= ismap.equal_range(45);
	cout << et.first->first<<":"<<et.first->second << endl;
	cout << et.second->first <<":"<<et.second->second<< endl;
	auto it = ismap.lower_bound(45);
	cout << it->first <<":"<< it->second << endl;
	auto pt = ismap.upper_bound(45);
	cout << pt->first << ":"<< pt->second << endl;

执行结果:在这里插入图片描述
通过结果结果发现equal_range函数返回的是两个迭代器,而lower_bound和upper_bound返回的是一个迭代器,分别是首个不小于待查找的元素和首个大于带查找值得元素。

遍历方式

执行下面语句,判断其结果:

int main() {
	std::map<int, std::string> ismap;
	ismap[12] = "yhping";
	ismap[34] = "xjq";
	ismap[23] = "hx";
	ismap[67] = "dxw";
	ismap[45] = "yx";
	ismap[56] = "dy";
	auto p = ismap.begin();
	for (; p != ismap.end(); ++p) {
		cout << p->first <<" : " <<p->second<< endl;
	}
}

这段代码便是要我们遍历map容器,结果如下:
在这里插入图片描述
也可以通过map定义时加入geater< int >参数来改变存储顺序。通过上面执行结果我们可以看出,迭代器的首个元素指向关键码最小的位置,而末尾便是最大的位置。遍历的时候是按照中序遍历的顺序进行遍历,但是我们明明对迭代器进行了++操作,所以总觉得是对其进行了+1,而本质上是通过调用函数来移动到其直接后继。

插入

map容器插入时如果其中存在相同关键码,便只会插入一个。

int main() {
	std::map<int, std::string> ismap;
	ismap.insert(std::map<int, std::string>::value_type(18, "dxw"));
	ismap.insert(std::map<int, std::string>::value_type(18, "sxl"));
	ismap.insert(std::map<int, std::string>::value_type(12, "yhping"));
	ismap.insert(std::map<int, std::string>::value_type(12, "wt"));
	ismap.insert(std::map<int, std::string>::value_type(34, "newdata"));
	ismap.insert(std::map<int, std::string>::value_type(23, "yx"));
	ismap.insert(std::map<int, std::string>::value_type(24, "fjx"));
	ismap.insert(std::map<int, std::string>::value_type(22, "data"));
	for (auto& x : ismap) {
		cout << x.first << ":" << x.second << endl;
	}
}

结果:在这里插入图片描述

所以此时就要用多重map,

multimap

多重map可以存放关键码相同得数据,如下

int main() {
	std::multimap<int, std::string> ismap;
	ismap.insert(std::multimap<int, std::string>::value_type(18, "dxw"));
	ismap.insert(std::multimap<int, std::string>::value_type(18, "sxl"));
	ismap.insert(std::multimap<int, std::string>::value_type(12, "yhping"));
	ismap.insert(std::multimap<int, std::string>::value_type(12, "wt"));
	ismap.insert(std::multimap<int, std::string>::value_type(34, "newdata"));
	ismap.insert(std::multimap<int, std::string>::value_type(23, "yx"));
	ismap.insert(std::multimap<int, std::string>::value_type(24, "fjx"));
	ismap.insert(std::multimap<int, std::string>::value_type(22, "data"));

	for (auto& x :ismap) {
		cout << x.first << ":" << x.second << endl;
	}
}

使用了多重map之后就会发现可以存放多个关键码相同得元素,
在这里插入图片描述
如果在此时用equal_range函数,会出现什么情况呢?
我们可以在上面代码得前提下执行下面代码

auto it = ismap.equal_range(18);
	for (auto p = it.first; p != it.second; ++p) {
		cout << p->first << " : " << p->second << endl;
	}

得到结果便是关键码为18得两个迭代器。如果在容器中没有关键码为18得值,返回得两个迭代器和有序map一样,返回的是指向首个不小于和首个大于关键码的迭代器。

set

set容器智能存放一种类型,其底层也是红黑树,遍历是有序的,其插入的参数有两个,一个是要插入的关键码类型,另一个是bool类型,可以通过bool类型的返回值判断是否插入成功。

int main() {
	std::set<int> iset;

	for (int i = 0; i < 100; ++i) {
		auto it=iset.insert(rand()%100);
		if (it.second) {
			cout << "insert seccod" << endl;
		}
		else {
			cout << "已经有重复值" << endl;
			cout << *it.first << endl;
		}
	}
	std::set<int>::iterator it = iset.begin();
	for (; it != iset.end(); ++it) {
		cout << *it << endl;
	}
}

unordered_map

通过代码比较map和unordered_map的区别

int main() {
	std::map<int, std::string> ismap;
	std::unordered_map<int, std::string> isunmap;
	ismap[12] = "yhping";
	ismap[34] = "xjq";
	ismap[23] = "hx";
	ismap[67] = "dxw";
	ismap[45] = "yx";
	ismap[56] = "dy";


	isunmap[12] = "yhping";
	isunmap[34] = "xjq";
	isunmap[23] = "hx";
	isunmap[67] = "dxw";
	isunmap[45] = "yx";
	isunmap[56] = "dy";

	cout << "map" << endl;
	for (auto& x : ismap) {
		cout << x.first << ":" << x.second << endl;
	}
	cout << "------------------------" << endl;
	cout << "undered_map" << endl;
	for (auto& x : isunmap) {
		cout << x.first << ":" << x.second << endl;
	}
	return 0;
}

我们通过代码可以发现其区别和名字一样,一个是有序的一个是无序的,这是为什么呢?
无需map的底层实际上不是红黑树,而是哈希桶,我们可以通过画图来理解其底层结构。
在这里插入图片描述
这里桶中结点个数是10个,所以存放结点是这样存放的,关键码对10取余,得到的结果是多少就存放在那个结点后面,存放的方式便是链表。而如果数据量太大的情况下,而桶中结点个数很少,这样导致一个结点后的元素个数很多,遍历时元素效率就很低,所以桶的也会进行扩容(更改10),然后重构哈希表(桶)。而每当结点个数等于桶中元素个数时就会扩容。

map和无序map的异同

map

优点:底层是红黑树,其有序性可以在很多的操作中应用,复杂度logN
缺点:空间占用率高,每个结点都需要存指针来指向父节点和子节点,以及红黑性质,所以每个结点都占用了大量空间。
适用范围:对那些有顺序要求的问题,用map会很高效。

unordered_map

优点:底层是哈希表,为此查找速度很快,时间复杂度为O(1);
缺点:更改哈希表的大小,重构哈希表比较浪费时间。
使用范围:对于查找问题,使用无序map会比较高效。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/616013.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

数组降维

写一个函数&#xff0c;打印数组内的内容&#xff0c;代码为&#xff1a; #include<stdio.h>void show_arr(int arr[], int num) {int i 0;for (i 0; i < num; i){printf("%d ", arr[i]);}printf("\n"); } int main() {int arr[] { 1,2,3,4,5…

Servlet Cookie基本概念和使用方法

目录 Cookie 介绍 Cookie 主要有两种类型&#xff1a;会话 Cookie 和持久 Cookie。 Cookie使用步骤 使用Servlet和Cookie实现客户端存储的登录功能示例&#xff1a; LoginServlet类 index.jsp 删除Cookie 浏览器中查看Cookie的方法 Cookie 介绍 Cookie 是一种在网站和…

win10下载安装mysql8.0版本

打开官网下载&#xff1a;https://dev.mysql.com/downloads/mysql/ 下载完成后解压&#xff0c;这里我是直接放在C盘 然后打开mysql目录文件夹新建my.ini文件,my.ini文件内容如下&#xff0c;需要修改两个地方&#xff0c;其中datadir你自己的mysql的安装目录&#xff0c;data…

如何在线压缩png图片?png压缩图片大小的方法介绍

压缩PNG图片大小的优点 随着数字化时代的发展&#xff0c;PNG格式已成为一种常见的图片格式。然而&#xff0c;由于高分辨率、高色深等原因&#xff0c;PNG图片通常具有较大的文件体积&#xff0c;导致在传输、存储和网页加载等方面会产生不必要的负担。因此&#xff0c;对于需…

ai绘画生成古风场景怎么弄?告诉你怎么ai绘画

随着人工智能技术的不断发展&#xff0c;ai绘画已经成为一个令人着迷的领域。一些软件利用深度学习算法和生成对抗网络等技术&#xff0c;能够帮助艺术家和爱好者创造出令人惊叹的艺术作品。今天我就来跟大家分享一下如何一键ai绘画&#xff0c;感兴趣的朋友就跟我一起看下去吧…

《文体用品与科技》期刊简介及投稿要求

《文体用品与科技》期刊简介&#xff1a; 主管单位&#xff1a;中国轻工业联合会 主办单位&#xff1a;中国文教体育用品协会、全国文教体育用品信息中心、北京市文教体育用品研究所 国际刊号&#xff1a; ISSN1006-8902 国内刊号;CN:11-3762/TS 邮发代号;82-21932 发表周…

DDR跑不到速率后续来了,相邻层串扰深度分析!

高速先生成员&#xff1a;黄刚 就在刚刚&#xff0c;雷豹把他对叠层的调整方式和改善后的仿真结果给师傅Chris看完后&#xff0c;Chris给雷豹点了个大大的赞&#xff0c;因为优化的方式其实不需要大改DDR的走线&#xff0c;只需要把相邻层的信号最大限度的拉开&#xff0c;同时…

如何定位分析视频异常画面

背景 视频典型画面不正常主要包含画面卡顿、画面模糊、画面不显示、画面花屏这 4 类问题。本文主要介绍的是画面花屏的情况&#xff0c;这里的画面花屏包含了花屏、闪屏、绿屏、黑屏。视频花屏是多媒体工程师最常见的问题之一&#xff0c;也是最棘手的问题之一&#xff0c;笔者…

有什么可靠稳定的微信管理系统?

微信管理系统是什么 微信管理系统从字面上来说可以理解为微信的管理和营销系统。通俗一点来说就是利用微信与管理营销相结合的一种新型办公方式。 不用下载任何软件&#xff0c;不用多部手机&#xff0c;对手机没有任何型号要求&#xff0c;不需要刷机、越狱&#xff0c;不需…

政务APP小程序开发 畅享全新政府办事体验

现在很多政府机构打着便民的口号&#xff0c;但其实生活中很多时候去政府机构办事都很费时间&#xff0c;周末节假日不上班没法办理&#xff0c;工作日去人多排长队不说&#xff0c;往往排到自己了又因为资料不全、手续不齐&#xff0c;无法证明自己等奇葩原因不得不一次次被拒…

boost 搜索引擎

boost搜索引擎 01 项目演示 done 02 讲解思路 03 项目背景 公司&#xff1a;百度、搜狗、360搜索、头条新闻客户端 - 我们自己实现是不可能的&#xff01; 站内搜索&#xff1a;搜索的数据更垂直&#xff0c;数据量其实更小 boost的官网是没有站内搜索的&#xff0c;需要…

家乡乐山美食网站系统(含源码+数据库)

1.需求分析 将进行家乡乐山美食网站的需求分析。需求分析是系统开发过程中的一项重要工作&#xff0c;它是对用户需求进行深入研究和分析&#xff0c;明确系统的功能、性能、界面等方面的需求&#xff0c;为后续的设计和开发提供依据。 首先&#xff0c;需要明确该网站的主要目…

成为一个优秀的测试工程师需要具备哪些知识和经验?

目录 前言&#xff1a;  1、我们先来讲第一点&#xff0c;由单纯的测试变成项目质量保证工作 2、持续集成探索和自动化测试技术研究 3、测试相关工具的开发 总结忠告 前言&#xff1a;  本人7年测试经验&#xff0c;在学测试之前对电脑的认知也就只限于上个网&#xff0c;…

狂野java前置课程-线程池的基本使用

回顾 什么是线程&#xff0c;什么是进程&#xff1f; 进程&#xff1a;是一个应用程序&#xff0c;里面包含很多线程线程&#xff1a;进程执行的基本单元 java实现线程的几种方式 继承Thread类实现Runable接口 线程的生命周期 执行线程会出现的问题 一个线程只能执行一个…

【专为苛刻的数据环境而构建】上海道宁为您带来世界上先进的矢量原生、时间序列和实时分析数据库——kdb系列产品

kdb是高效的矢量原生 时间序列和实时分析数据库 专为高性能矢量 数据驱动的应用程序而构建 以加速云端、数据仓库和 数据湖中的 AI 和 ML 工具 从而更快、更高效地 制定业务决策 使用数据时间库加速数据 分析和生成 AI 管道 以降低成本 提高性能并提高效率 开发商介绍…

移动端图形API通讲(一)--从Gles、Vulkan到Metal

转载请注明&#xff0c;来自leonnwei的csdn blog 引言 一直想整理下关于移动端图形编程API的文档。图形API为何重要&#xff1f;如果说图形编程的内功是计算机图形学的诸原理和算法&#xff0c;那么外功就是实实在在的硬件API。不能精通API的使用&#xff0c;就无法把渲染特性合…

新来个技术总监,把限流实现的那叫一个优雅,佩服!

在电商高并发场景下&#xff0c;我们经常会使用一些常用方法&#xff0c;去应对流量高峰&#xff0c;比如限流、熔断、降级&#xff0c;今天我们聊聊限流。 什么是限流呢&#xff1f;限流是限制到达系统的并发请求数量&#xff0c;保证系统能够正常响应部分用户请求&#xff0…

人脸比对指标 -- 人脸相似度

目前市面上既有OpenCV等开源算法库&#xff0c;很多芯片厂商的产品也自带简单算法&#xff0c;同时专业算法大厂也会开放相关技术&#xff0c;如提供免费、离线人脸识别SDK的虹软视觉开放平台等。对于开发者而言&#xff0c;面对多种算法&#xff0c;如何进判断算法性能至关重要…

Vue初始化项目加载逻辑

Vue初始化项目加载逻辑 项目创建 我们只需要创建项目即可&#xff0c;剩余的依赖都没必要安装 我们先来看main.js,咱们加了一行备注 import Vue from vue import App from ./App.vue import router from ./router import store from ./storeVue.config.productionTip fals…

汇众智,奔涌向前赢未来 | 2023开放原子全球开源峰会 OpenAtom openEuler 分论坛即将启幕

OpenAtom openEuler&#xff08;以下简称“openEuler”&#xff09;自 2021 年贡献给开放原子开源基金会后&#xff0c;步入高速发展阶段&#xff0c;社区每日活跃开发者近 4000 人&#xff0c;新增讨论 2168 次&#xff0c;代码合入 127 个、软件包 31 个&#xff1b;每月新增…