C++从零开始(day52)——unordered_set,unordered_map学习使用

2024-03-17 16:52

本文主要是介绍C++从零开始(day52)——unordered_set,unordered_map学习使用,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.unordered系列关联式容器

C++98中,STL提供了底层为红黑树结构的一系列容器,在查找时效率可以达到时间复杂度可以达到O(logN),即红黑树的高度次,当树中的结点非常多时,查询效率也不理想,因此在C++11中,STL又提供了4个unordered系列的关联式容器,者四个容器与红黑树结构的关联式容器使用方法类似,只是其底层结构不同,这里只介绍unordered_set,unordered_map,关于unordered_multiset,unordered_multiset与其大同小异,这里不再花大量篇幅赘述

2.unordered_set,unordered_map的使用

与set,map相似,要注意的是

1.unordered_map,unordered_set遍历输出是无序的

2.unordered_map,unordered_set不支持反向迭代器

3.关于unordered_set,unordered_map的一些题目

1.在长度2N的数组中找出重复N次的元素

961. 在长度 2N 的数组中找出重复 N 次的元素

给你一个整数数组 nums ,该数组具有以下属性:

  • nums.length == 2 * n.
  • nums 包含 n + 1 个 不同的 元素
  • nums 中恰有一个元素重复 n 次

找出并返回重复了 n 次的那个元素

使用unordered_map计数,在遍历找出符合条件的数据返回即可

class Solution {
public:int repeatedNTimes(vector<int>& nums) {unordered_map<int, int> um;for(auto e : nums){++um[e];}int sz = nums.size();for(auto e : um){if(e.second == sz/2){return e.first;}}return 0;}
};

这是ac代码

2.两个数组的交集1

349. 两个数组的交集

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

因为输出结果中元素是唯一的,所以先利用unordered_set对其进行存储并去重,再遍历其中一个,在另一个中找元素是否存在来判断它是否需要输出

class Solution {
public:vector<int> intersection(vector<int>& nums1, vector<int>& nums2){vector<int> ret;unordered_set<int> s1;unordered_set<int> s2;for(auto e : nums1)s1.insert(e);for(auto e : nums2)s2.insert(e);for(auto e : s1){if(s2.find(e) != s2.end())ret.push_back(e);}return ret;}
};

这是ac代码

3.两个数组的交集2

350. 两个数组的交集 II

给你两个整数数组 nums1 和 nums2 ,请你以数组形式返回两数组的交集。返回结果中每个元素出现的次数,应与元素在两个数组中都出现的次数一致(如果出现次数不一致,则考虑取较小值)。可以不考虑输出结果的顺序

由于输出元素中重复的要多次输出,并且按小的来,我们用unordered_map对其中一个vector的数据进行存储并计数,再遍历另一个数组,如果里面的数字可以找到,对计数位进行减减,压入输出vector中,最后输出

class Solution {
public:vector<int> intersect(vector<int>& nums1, vector<int>& nums2) {vector<int> v;unordered_map<int, int> um;for(auto e : nums1)++um[e];for(auto e : nums2){if(um[e]){--um[e];v.push_back(e);}} return v;}
};

这是ac代码

4.存在重复元素

217. 存在重复元素

给你一个整数数组 nums 。如果任一值在数组中出现 至少两次 ,返回 true ;如果数组中每个元素互不相同,返回 false

直接计数,如果计数位有大于等于2的返回false,反之返回true

class Solution {
public:bool containsDuplicate(vector<int>& nums) {unordered_map<int, int> um;for(auto e : nums){++um[e];if(um[e] >= 2)return true;}return false;}
};

这是ac代码

5.两句话中的不常见单词

884. 两句话中的不常见单词

句子 是一串由空格分隔的单词。每个 单词 仅由小写字母组成。

如果某个单词在其中一个句子中恰好出现一次,在另一个句子中却 没有出现 ,那么这个单词就是 不常见的 

给你两个 句子 s1 和 s2 ,返回所有 不常用单词 的列表。返回列表中单词可以按 任意顺序 组织。

理解题目,不难有以下思路,将s1,s2加上空格后合并在一起,用unordered_map对其计数后返回只出现一次的单词即可

class Solution {
public:vector<string> uncommonFromSentences(string s1, string s2) {vector<string> ret;unordered_map<string, int> um;s1 += " ";s1 += s2;int begin = 0, end = 0;int sz = s1.size();while(end <= sz){if(s1[end] == ' ' || end == sz){string s;while(begin < end){s += s1[begin];++begin;}++um[s];++end;++begin;}else{++end;}}for(auto e : um){if(e.second == 1)ret.push_back(e.first);}return ret;}
};

新手写博客,有不对的位置希望大佬们能够指出,也谢谢大家能看到这里,让我们一起学习进步吧!

这篇关于C++从零开始(day52)——unordered_set,unordered_map学习使用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/819557

相关文章

C++右移运算符的一个小坑及解决

《C++右移运算符的一个小坑及解决》文章指出右移运算符处理负数时左侧补1导致死循环,与除法行为不同,强调需注意补码机制以正确统计二进制1的个数... 目录我遇到了这么一个www.chinasem.cn函数由此可以看到也很好理解总结我遇到了这么一个函数template<typename T>unsigned

Python使用FastAPI实现大文件分片上传与断点续传功能

《Python使用FastAPI实现大文件分片上传与断点续传功能》大文件直传常遇到超时、网络抖动失败、失败后只能重传的问题,分片上传+断点续传可以把大文件拆成若干小块逐个上传,并在中断后从已完成分片继... 目录一、接口设计二、服务端实现(FastAPI)2.1 运行环境2.2 目录结构建议2.3 serv

Spring Security简介、使用与最佳实践

《SpringSecurity简介、使用与最佳实践》SpringSecurity是一个能够为基于Spring的企业应用系统提供声明式的安全访问控制解决方案的安全框架,本文给大家介绍SpringSec... 目录一、如何理解 Spring Security?—— 核心思想二、如何在 Java 项目中使用?——

springboot中使用okhttp3的小结

《springboot中使用okhttp3的小结》OkHttp3是一个JavaHTTP客户端,可以处理各种请求类型,比如GET、POST、PUT等,并且支持高效的HTTP连接池、请求和响应缓存、以及异... 在 Spring Boot 项目中使用 OkHttp3 进行 HTTP 请求是一个高效且流行的方式。

Java使用Javassist动态生成HelloWorld类

《Java使用Javassist动态生成HelloWorld类》Javassist是一个非常强大的字节码操作和定义库,它允许开发者在运行时创建新的类或者修改现有的类,本文将简单介绍如何使用Javass... 目录1. Javassist简介2. 环境准备3. 动态生成HelloWorld类3.1 创建CtC

使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解

《使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解》本文详细介绍了如何使用Python通过ncmdump工具批量将.ncm音频转换为.mp3的步骤,包括安装、配置ffmpeg环... 目录1. 前言2. 安装 ncmdump3. 实现 .ncm 转 .mp34. 执行过程5. 执行结

Java使用jar命令配置服务器端口的完整指南

《Java使用jar命令配置服务器端口的完整指南》本文将详细介绍如何使用java-jar命令启动应用,并重点讲解如何配置服务器端口,同时提供一个实用的Web工具来简化这一过程,希望对大家有所帮助... 目录1. Java Jar文件简介1.1 什么是Jar文件1.2 创建可执行Jar文件2. 使用java

C++统计函数执行时间的最佳实践

《C++统计函数执行时间的最佳实践》在软件开发过程中,性能分析是优化程序的重要环节,了解函数的执行时间分布对于识别性能瓶颈至关重要,本文将分享一个C++函数执行时间统计工具,希望对大家有所帮助... 目录前言工具特性核心设计1. 数据结构设计2. 单例模式管理器3. RAII自动计时使用方法基本用法高级用法

C#使用Spire.Doc for .NET实现HTML转Word的高效方案

《C#使用Spire.Docfor.NET实现HTML转Word的高效方案》在Web开发中,HTML内容的生成与处理是高频需求,然而,当用户需要将HTML页面或动态生成的HTML字符串转换为Wor... 目录引言一、html转Word的典型场景与挑战二、用 Spire.Doc 实现 HTML 转 Word1

Java中的抽象类与abstract 关键字使用详解

《Java中的抽象类与abstract关键字使用详解》:本文主要介绍Java中的抽象类与abstract关键字使用详解,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录一、抽象类的概念二、使用 abstract2.1 修饰类 => 抽象类2.2 修饰方法 => 抽象方法,没有