map和set(C++)

news2024/11/16 13:41:11

1.关联式容器

关联式容器:内部储存的是key或者k-v模型的数据

k-v模型:键值对

在STL中,键值对实际就是一个泛型的类,pair---->first(key)  second(value)

分类:从底层数据结构上

红黑树结构   :                                                                                     哈希结构

map :k-v  key必须唯一

multimap:k-v key可以重复的

set:k模型  key  key不能重复

multiset:k模型   key可以重复的

红黑树特性:借助迭代器遍历(中序遍历)时,可以得到关于key有序的结果。时间复杂度:O(logN) 

 map:

键值对:

 用来表示具有一一对应关系的一种结构,该结构中一般只包含两个成员变量key和value,key代 表键值,value表示与key对应的信息。比如:现在要建立一个英汉互译的字典,那该字典中必然 有英文单词与其对应的中文含义,而且,英文单词与其中文含义是一一对应的关系,即通过该应 该单词,在词典中就可以找到与其对应的中文含义。

 map的应用:

(1)

#include<map>

void TestMap1()
{
	map<string, string> m1;

	//c++11
	map<string, string>m2{ { "apple", "苹果" }, { "orange", "橘子" }, { "pear", "梨" } };


	//采用区间的方式构造
	map<string, string>m3(m2.begin(), m2.end());
	
}

void TestMap2()
{
	map<string, string>m;

	pair<string, string>kv("pear", "梨");
	m.insert(kv);
	
	m.insert(pair<string, string>("grape", "葡萄"));
	m.insert(pair<string, string>("apple", "苹果"));
	m.insert(make_pair("orange", "橘子"));
	m.insert(make_pair("banana", "香蕉"));

	
	cout << m.size() << endl;

	//*********************************************************************
	
	//map::operator[]
	//如果key存在,返回与key对应的value
	cout << m["orange"] << endl;

	//如果key不存在,则使用key与默认的value组成键值对
	//插入到map中,然后返回该key对应的默认value
	//<"watermelon"," ">
	cout << m["watermelon"] << endl;

	//可以修改value ,但key不能修改。
	m["watermelon"] = "西瓜";
	
	//*********************************************************************

	
	
	//范围for  || 采用迭代器遍历,最终得到都是关于key的有序序列
	//因为它们的底层都是中序遍历
	for (auto& e : m)
	{
		cout << e.first << "---->" << e.second << endl;
	}

	cout << "------------------------------------" << endl;


	//std::map<std::string, std::string>::iterator it = m.begin();
	auto it = m.begin();
	while (it!=m.end())
	{
		cout << it->first << "---->" << it->second << endl;
		++it;
	}

}

int main()
{
	TestMap2();
	return 0;
}

 (2)

#include<functional>
void TestMap3()
{
	map<string, string,greater<string>>m;

	m.insert(pair<string, string>("pear", "梨"));

	m.insert(pair<string, string>("grape", "葡萄"));
	m.insert(pair<string, string>("apple", "苹果"));
	m.insert(make_pair("orange", "橘子"));
	m.insert(make_pair("banana", "香蕉"));

	for (auto& e : m)
	{
		cout << e.first << "----->" << e.second << endl;
	}

	cout << "------------------------------------" << endl;
#if 0
	//find
	auto it = m.find("apple");
	if (it != m.end())
	{
		cout << it->second << endl;
		it++;
	}
	else
	{
		cout << "apple不存在" << endl;
	}

	m.erase("apple");

#endif

	//注意:map中的key不能修改---因为要保证关于key有序,如果修改之后不一定有序
	//如果一定要修改,则先删除该key,然后重新插入
	m.erase("orange");
	m.insert(make_pair("tangerine", "橙子"));

	for (auto& e : m)
	{
		cout << e.first << "----->" << e.second << endl;
	}

	
}

 multimap:

void TestMap4()
{
	multimap<string, string>m;

	m.insert(pair<string, string>("pear", "梨"));

	m.insert(pair<string, string>("grape", "葡萄"));
	m.insert(pair<string, string>("apple", "苹果"));
	m.insert(make_pair("orange", "橘子"));
	m.insert(make_pair("banana", "香蕉"));

	//主要区别就是key可以重复
	m.insert(make_pair("orange", "橙子"));

	cout << m.size() << endl;

    for (auto& e : m)
	{
		cout << e.first << "----->" << e.second << endl;
	}

	

}


  set和multiset:

#include<set>

void TestSet()
{
	//set去重+排序
	int array[] = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 9, 8, 7, 6, 5, 4, 3, 2, 1 };
	set<int> s(array, array + sizeof(array) / sizeof(array[0]));

	for (auto e : s)
	{
		cout << e << " ";
	}
	cout << endl;

	//multiset:排序


	multiset<int> ms(array, array + sizeof(array) / sizeof(array[0]));

	for (auto e : ms)
	{
		cout << e << " ";
	}
	cout << endl;
}

 

 例题:

1.两个数组交集;

给定两个数组 nums1 和 nums2 ,返回 它们的 交集 。输出结果中的每个元素一定是 唯一 的。我们可以 不考虑输出结果的顺序 。

示例 1:

输入:nums1 = [1,2,2,1], nums2 = [2,2]
输出:[2]

示例 2:

输入:nums1 = [4,9,5], nums2 = [9,4,9,8,4]
输出:[9,4]
解释:[4,9] 也是可通过的
class Solution {
public:
    vector<int> intersection(vector<int>& nums1, vector<int>& nums2) {
         vector<int>vRet;

         set<int> s1(nums1.begin(),nums1.end()); //set去重
         set<int> s2(nums2.begin(),nums2.end());//set去重

         for(auto e:s1)
         {
            if(s2.find(e)!=s2.end())
            {
                vRet.push_back(e);
            }
         }
         return vRet;

    }
};

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

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

相关文章

单击视角复位按钮,即可看到整个地球【mars3d】

1.需要设置下初始默认视角&#xff0c;地图属性参数里面得 scene: { center: { 这个需要拿到一个参数&#xff0c;可以在示例里面随便抓一个想要的右键获取下 拿到之后再设置下&#xff0c;参考代码之后&#xff0c;就可以单击视角复位按钮&#xff0c;就回到可以看到整个地球…

19050 牛牛打气球

### 思路 1. **输入读取**&#xff1a; - 读取 n&#xff0c;a 和 b。 - 读取每个气球的坚韧度。 2. **计算最少释放次数**&#xff1a; - 使用二分查找来确定最少的释放次数。 - 每次释放武器时&#xff0c;选择一个气球多承受 a 点伤害&#xff0c;其他气球承受…

最简洁!四步完成C#——opencv环境配置

一.创建C#环境 二.右键点击管理NuGet 三.下载opencv环境 四.测试写入 using OpenCvSharp 不保存就完成了配置啦

Cycle inside Runner; building could produce unreliable results.

报错 Showing Recent Messages Cycle inside Runner; building could produce unreliable results. Cycle details: → Target Runner ○ That command depends on command in Target Runner: script phase “Thin Binary” ○ Target Runner has process command with outpu…

性能测试的基本概念

学习前的认知 我们在学习性能测试之前&#xff0c;需要有个新的认识&#xff1a;性能测试&#xff0c;不再是像功能测试一样单纯的找 Bug&#xff0c;而是去找性能指标 转变思维 在做功能测试、自动化测试的时候&#xff0c;我们基本都是依托界面进行测试&#xff0c;也称 GU…

人工智能训练师工作内容及职业发展路径

人工智能训练师&#xff08;AI Trainer&#xff09;是一种专业职位&#xff0c;主要负责训练和优化人工智能系统&#xff0c;尤其是机器学习模型。他们的工作涉及到以下几个方面&#xff1a; 1、数据准备&#xff1a;训练师需要收集、清洗和预处理数据&#xff0c;以确保数据的…

大语言模型训练数据常见的4种处理方法

大语言模型训练需要数万亿的各类型数据。如何构造海量“高质量”数据对于大语言模型的训练具有至关重要的作用。虽然&#xff0c;截止到2023 年9 月为止&#xff0c;还没有非常好的大模型的理论分析和解释&#xff0c;也缺乏对语言模型训练数据的严格说明和定义。但是&#xff…

rabbitmq发送的消息接收不到

1.消息被其他消费者消费 2.主要说的2这种情况&#xff0c;就是在延迟队列中&#xff0c;忘记给一个bean加注解导致日志报exchange not found. 这个报错&#xff0c;进而引发了bindings没有绑定。没有绑定的话&#xff0c;发送消息就会接收不到。

python-带空格的数字层三角形

[题目描述] 输入一个整数n&#xff0c;输出一个带空格的数字层状三角形。输入&#xff1a; 输入共一行&#xff0c;为一个整数n。输出&#xff1a; 输出一个带空格的数字层状三角形。样例输入1 8 样例输出1 11111111 2222222 333333 44444 5555 …

亦菲喊你来学机器学习(16) --K-means聚类算法

文章目录 K-means基本步骤优缺点构建模型 总结 K-means K-means 算法是一种广泛使用的聚类算法&#xff0c;旨在将数据集划分为 K 个簇&#xff0c;使得每个簇内的数据点尽可能相似&#xff0c;而不同簇之间的数据点尽可能不同。这个算法通过迭代的方式实现&#xff0c;每次迭…

三耐环保家族控股99.17%:分红6000多万再补流,董事长董秘一年3次被警示

《港湾商业观察》施子夫 王璐 持续冲刺北交所的杭州三耐环保科技股份有限公司&#xff08;以下简称&#xff0c;三耐环保&#xff09;日前收到第三轮审核问询函&#xff0c;其保荐机构为民生证券。 值得关注的是&#xff0c;第三轮审核问询函依旧围绕的问题是&#xff0c;进…

linux系统修改/etc/profile,修改错了,再打开乱码

执行vim /etc/profile&#xff0c; 在文件末尾增加两行配置&#xff0c;可能是$符号写错了&#xff0c;输入:x保存&#xff0c;提示输入密码(help cm),然后输入两次cm 执行source /etc/profile 提 示文件错误字段 执行cat profile结果如下&#xff1a; 这有没有办法还原啊…

省略号(一行多行)vue3

组件 <template><div ref"tooltipParentRef" class"moreTipText"><el-tooltip:placement"props.placement"effect"dark":enterable"true":show-after"200":offset"10":popper-class&qu…

声纹API验证快速检索技术实现

一、实现思路&#xff0c;假如我们有4个人员&#xff0c;要从中快速找到4号的发音&#xff0c;那么我们就可以使用声纹API验证技术。 二、首先我们要创建特征库&#xff0c;然后分别添加到特征库里&#xff0c;随后找另一个人发音不同的音频去快速定位寻找。 三、比如我们要找到…

什么是集成测试?它和系统测试的区别是什么?

01 什么是集成测试&#xff1f; 集成测试是软件测试的一种方法&#xff0c;用于测试不同的软件模块之间的交互和协作是否正常。集成测试的主要目的是确保不同的软件模块能够无缝协作&#xff0c;形成一个完整的软件系统&#xff0c;并且能够满足系统的需求和规格。 在集成测试…

yml Unused property

问题描述 以前用的好好的项目,今天突然打开就发现idea不识别spring配置信息显示未引用,如果config代码中引入的配置却可以高亮显示,然后输入spring相关的配置,文件是没有提示的。经过研究发现是spring相关的插件被关闭了。效果如下 解决方法 启用三个插件spring Boot,Sp…

openEuler:ssh 管理和安全

ssh 简介 ssh 为 secure shell&#xff0c;是一种网络安全协议&#xff0c;通过加密和认证的方式实现远程安全登录&#xff0c;文件传输等服务。利用 SSH 协议可以有效防止远程管理过程中的信息泄露问题。 但是在近期&#xff0c;OpenSSH 爆出首个远程执行漏洞 CVE-2024-6387 …

R18 XR :NR L2 enhancement

这篇主要看下为支持XR,L2都有哪些增强。主要分3个部分:(1)additionalBS-TableAllowed和Delay Status Report(DSR) (2)UE assistance info for UL traffic information (3) PDU set discard。正文开始: 为了增强 XR 上行资源的调度,引入了以下改进: (1)一个额外的buffer s…

c++类(中)续

c类&#xff08;中&#xff09;续 一、日期类&#xff08;1&#xff09;什么是日期类&#xff1f;&#xff08;2&#xff09;日期类的初始化与销毁&#xff08;3&#xff09;我们需要完成的操作(1)初始化与输出日期&#xff08;2&#xff09;日期加等于天数&#xff08;3&#…

Linux实现进度条小程序——缓冲区

&#x1f4dd;Linux实现进度条小程序 &#x1f4dd; 行缓冲区&#x1f4dd; fflush函数&#x1f4dd; 示例&#x1f4dd; 进度条如何编译运行proc.hproc.cmain.c 好雨知时节 当春乃发生 随风潜入夜 润物细无声 回车换行其实是两个概念&#xff0c;一是回车&#xff0c;一是换行…