代码随想录算法训练营第六天| 哈希表理论基础、242.有效的字母异位词、349. 两个数组的交集、202. 快乐数、1. 两数之和

本文主要是介绍代码随想录算法训练营第六天| 哈希表理论基础、242.有效的字母异位词、349. 两个数组的交集、202. 快乐数、1. 两数之和,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

常见的三种哈希结构:vector数组、set (集合)、map(映射)

哈希表理论基础

常见的三种哈希结构:vector数组、set (集合)、map(映射)

242.有效的字母异位词

固定类别的存储内查找用固定大小的vector;
思路:
1、26种英文字符分别记录两字符串中各种字符的数量;
2、若两字符串相互抵消,则最终vector元素全为0

固定大小的vector

class Solution {
public:bool isAnagram(string s, string t) {if(s.size() != t.size()) return false;vector<int> V(26);for(int i = 0; i < s.size();i++){V[s[i]-'a']++;V[t[i]-'a']--;}for(int i = 0; i < V.size();i++){if(V[i] != 0) return false;}return true;}
};

349. 两个数组的交集

一、set的使用:
1、初始化 unordered_set antherNum(nums1.begin(),nums1.end());
2、查找特定元素 antherNum.find(nums2[i]) != antherNum.end();
二、思路:
1、先用一个set1保存数组1的元素
2、遍历数组2的元素若存在于set1,则将元素加入交集set2(消除重复元素

unordered_set

class Solution {
public:vector<int> intersection(vector<int>& nums1, vector<int>& nums2) {unordered_set<int> antherNum(nums1.begin(),nums1.end());unordered_set<int> result{};for(int i = 0; i < nums2.size(); i++){if(antherNum.find(nums2[i]) != antherNum.end()){result.insert(nums2[i]);}}vector<int> resultV(result.begin(),result.end());return resultV;}
};

202. 快乐数

一、int getNewnum(int num):%除余操作获取每位数字
二、思路:
1、结束循环:确定是快乐数(1)或不是快乐数(出现重复数)
2、将已出现的数加入unordered_set集合,从而用来判断是否重复实现;

unordered_set

class Solution {
public:int getNewnum(int num){int sum = 0;while(num != 0){sum += (num%10)*(num%10);num /= 10;}return sum;}bool isHappy(int n) {if(n == 1) return true;unordered_set<int> getedNum{n};int newNum = getNewnum(n);while(newNum != 1){if(getedNum.find(newNum) != getedNum.end()) return false;getedNum.insert(newNum);newNum = getNewnum(newNum);}return true;}
};

1. 两数之和

一、unordered_map的使用:
1.初始化:unordered_map<int,int> anotherNums;
2.查找特定元素:anotherNums.find(nums[i]) != anotherNums.end()
3.映射的元素 pair<int,int>(target - nums[i],i)
二、思路
1、遍历数组,将目标值和当前元素值的差值、当前元素下标保存到unordered_map映射中
2、遍历数组时在unordered_map映射中寻找相同值的差值,组成一对两数之和为目标的元素下标

unordered_map

class Solution {
public:vector<int> twoSum(vector<int>& nums, int target) {unordered_map<int,int> anotherNums;vector<int> result(2);for(int i = 0; i < nums.size();i++){if(anotherNums.find(nums[i]) != anotherNums.end()){result[0] = anotherNums[nums[i]];result[1] = i;}else{anotherNums.insert(pair<int,int>(target - nums[i],i));}}return result;}
};

这篇关于代码随想录算法训练营第六天| 哈希表理论基础、242.有效的字母异位词、349. 两个数组的交集、202. 快乐数、1. 两数之和的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

C++中unordered_set哈希集合的实现

《C++中unordered_set哈希集合的实现》std::unordered_set是C++标准库中的无序关联容器,基于哈希表实现,具有元素唯一性和无序性特点,本文就来详细的介绍一下unorder... 目录一、概述二、头文件与命名空间三、常用方法与示例1. 构造与析构2. 迭代器与遍历3. 容量相关4

从基础到高级详解Go语言中错误处理的实践指南

《从基础到高级详解Go语言中错误处理的实践指南》Go语言采用了一种独特而明确的错误处理哲学,与其他主流编程语言形成鲜明对比,本文将为大家详细介绍Go语言中错误处理详细方法,希望对大家有所帮助... 目录1 Go 错误处理哲学与核心机制1.1 错误接口设计1.2 错误与异常的区别2 错误创建与检查2.1 基础

深入理解Mysql OnlineDDL的算法

《深入理解MysqlOnlineDDL的算法》本文主要介绍了讲解MysqlOnlineDDL的算法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小... 目录一、Online DDL 是什么?二、Online DDL 的三种主要算法2.1COPY(复制法)

JavaScript对象转数组的三种方法实现

《JavaScript对象转数组的三种方法实现》本文介绍了在JavaScript中将对象转换为数组的三种实用方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友... 目录方法1:使用Object.keys()和Array.map()方法2:使用Object.entr

Java集合之Iterator迭代器实现代码解析

《Java集合之Iterator迭代器实现代码解析》迭代器Iterator是Java集合框架中的一个核心接口,位于java.util包下,它定义了一种标准的元素访问机制,为各种集合类型提供了一种统一的... 目录一、什么是Iterator二、Iterator的核心方法三、基本使用示例四、Iterator的工

Java 线程池+分布式实现代码

《Java线程池+分布式实现代码》在Java开发中,池通过预先创建并管理一定数量的资源,避免频繁创建和销毁资源带来的性能开销,从而提高系统效率,:本文主要介绍Java线程池+分布式实现代码,需要... 目录1. 线程池1.1 自定义线程池实现1.1.1 线程池核心1.1.2 代码示例1.2 总结流程2. J

Spring的基础事务注解@Transactional作用解读

《Spring的基础事务注解@Transactional作用解读》文章介绍了Spring框架中的事务管理,核心注解@Transactional用于声明事务,支持传播机制、隔离级别等配置,结合@Tran... 目录一、事务管理基础1.1 Spring事务的核心注解1.2 注解属性详解1.3 实现原理二、事务事

JS纯前端实现浏览器语音播报、朗读功能的完整代码

《JS纯前端实现浏览器语音播报、朗读功能的完整代码》在现代互联网的发展中,语音技术正逐渐成为改变用户体验的重要一环,下面:本文主要介绍JS纯前端实现浏览器语音播报、朗读功能的相关资料,文中通过代码... 目录一、朗读单条文本:① 语音自选参数,按钮控制语音:② 效果图:二、朗读多条文本:① 语音有默认值:②

Vue实现路由守卫的示例代码

《Vue实现路由守卫的示例代码》Vue路由守卫是控制页面导航的钩子函数,主要用于鉴权、数据预加载等场景,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着... 目录一、概念二、类型三、实战一、概念路由守卫(Navigation Guards)本质上就是 在路

uni-app小程序项目中实现前端图片压缩实现方式(附详细代码)

《uni-app小程序项目中实现前端图片压缩实现方式(附详细代码)》在uni-app开发中,文件上传和图片处理是很常见的需求,但也经常会遇到各种问题,下面:本文主要介绍uni-app小程序项目中实... 目录方式一:使用<canvas>实现图片压缩(推荐,兼容性好)示例代码(小程序平台):方式二:使用uni