代码随想录算法训练营(JAVA) | 第三章 哈希表part01 DAY05

2024-02-27 06:36

本文主要是介绍代码随想录算法训练营(JAVA) | 第三章 哈希表part01 DAY05,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

   今日任务 

力扣242. 有效的字母异位词,349. 两个数组的交集,202. 快乐数,1. 两数之和

什么时候想到用哈希法,当我们遇到了要快速判断一个元素是否出现集合里的时候,就要考虑哈希法。

 什么时候使用哈希法,当我们需要查询一个元素是否出现过,或者一个元素是否在集合里的时候,就要第一时间想到哈希法。

使用数组和set来做哈希法的局限。

  • 数组的大小是受限制的,而且如果元素很少,而哈希值太大会造成内存空间的浪费。
  • set是一个集合,里面放的元素只能是一个key,而两数之和这道题目,不仅要判断y是否存在而且还要记录y的下标位置,因为要返回x 和 y的下标。所以set 也不能用。

242. 有效的字母异位词

思路

由于字符串只包含 26个小写字母,因此我们可以维护一个长度为 26 的频次数组 table,先遍历记录字符串 s 中字符出现的频次,然后遍历字符串 t,减去 table 中对应的频次

题解
class Solution {public boolean isAnagram(String s, String t) {if (s.length() != t.length()) {return false;}int[] hashTable = new int[26];for (int i = 0; i < s.length(); i ++ ) {hashTable[s.charAt(i) - 'a']++;}for (int i = 0; i < t.length(); i ++ ) {hashTable[t.charAt(i) - 'a']--;if (hashTable[t.charAt(i) - 'a'] < 0) {return false;}}return true;}
}

349. 两个数组的交集

思路

苦于 基础不牢语法不熟现去看了看基础依照思路写出来了

老是忘条件处理

题解
1.使用HashSet
class Solution {public int[] intersection(int[] nums1, int[] nums2) {if (nums1 == null || nums1.length == 0 || nums2 == null || nums2.length == 0) {return new int[0];}Set<Integer> set1 = new HashSet<>();Set<Integer> setList = new HashSet<>();for (int i : nums1) {set1.add(i);}for (int i : nums2) {if(set1.contains(i)) {setList.add(i);}}// 方法一: 将结果集合转化为数组// return setList.stream().mapToInt(x -> x).toArray();// 方法二: 创建一个新的数组存放setList中的值并返回int[] arr = new int[setList.size()];int flag = 0;for (int i : setList) {arr[flag++] = i;}return arr;}
}
2.使用哈希数组
class Solution {public int[] intersection(int[] nums1, int[] nums2) {int[] hash1 = new int[1010];int[] hash2 = new int[1010];List<Integer> resList = new ArrayList<>();for (int i : nums1) {hash1[i] ++;}for (int i : nums2) {hash2[i]++;}for (int i = 0; i < 1010; i ++) {if (hash1[i] > 0 && hash2[i] > 0) {resList.add(i);}}int index = 0;int[] res = new int[resList.size()];for (int i : resList) {res[index++] = i;}return res;}
}

202. 快乐数

思路

第一遍读题 emmmm没想法,看一眼提示   /思考  要存 set 也就是说这道题有重复的内容咯,每位数的平方和会重复!那也就是说会陷入循环,也就是说只要有重复内容就不是快乐数

题解
class Solution {public boolean isHappy(int n) {Set<Integer> set = new HashSet<>();while (n != 1 && !set.contains(n)) {set.add(n);n = getNext(n);}if (n == 1) {return true;}return false;}private int getNext(int n) {int sum = 0;while (n > 0) {int tmp = n % 10;sum += tmp * tmp;n /= 10;}return sum;}
}

1. 两数之和

思路

正如提示说的要用map KV,为什么用map呢?因为 要存 数值  和 下标 这两个值

题解 
class Solution {public int[] twoSum(int[] nums, int target) {int[] res = new int[2];Map<Integer, Integer> map = new HashMap<>();if (nums == null || nums.length == 0) {return res;}for (int i = 0; i < nums.length; i++ ) {int tmp = target - nums[i];if (map.containsKey(tmp)) {res[0] = map.get(tmp);res[1] = i;break;}map.put(nums[i], i);}return res;}
}

这篇关于代码随想录算法训练营(JAVA) | 第三章 哈希表part01 DAY05的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


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

相关文章

Java堆转储文件之1.6G大文件处理完整指南

《Java堆转储文件之1.6G大文件处理完整指南》堆转储文件是优化、分析内存消耗的重要工具,:本文主要介绍Java堆转储文件之1.6G大文件处理的相关资料,文中通过代码介绍的非常详细,需要的朋友可... 目录前言文件为什么这么大?如何处理这个文件?分析文件内容(推荐)删除文件(如果不需要)查看错误来源如何避

MySQL进行数据库审计的详细步骤和示例代码

《MySQL进行数据库审计的详细步骤和示例代码》数据库审计通过触发器、内置功能及第三方工具记录和监控数据库活动,确保安全、完整与合规,Java代码实现自动化日志记录,整合分析系统提升监控效率,本文给大... 目录一、数据库审计的基本概念二、使用触发器进行数据库审计1. 创建审计表2. 创建触发器三、Java

SpringBoot整合Dubbo+ZK注册失败的坑及解决

《SpringBoot整合Dubbo+ZK注册失败的坑及解决》使用Dubbo框架时,需在公共pom添加依赖,启动类加@EnableDubbo,实现类用@DubboService替代@Service,配... 目录1.先看下公共的pom(maven创建的pom工程)2.启动类上加@EnableDubbo3.实

SpringBoot整合(ES)ElasticSearch7.8实践

《SpringBoot整合(ES)ElasticSearch7.8实践》本文详细介绍了SpringBoot整合ElasticSearch7.8的教程,涵盖依赖添加、客户端初始化、索引创建与获取、批量插... 目录SpringBoot整合ElasticSearch7.8添加依赖初始化创建SpringBoot项

JAVA覆盖和重写的区别及说明

《JAVA覆盖和重写的区别及说明》非静态方法的覆盖即重写,具有多态性;静态方法无法被覆盖,但可被重写(仅通过类名调用),二者区别在于绑定时机与引用类型关联性... 目录Java覆盖和重写的区别经常听到两种话认真读完上面两份代码JAVA覆盖和重写的区别经常听到两种话1.覆盖=重写。2.静态方法可andro

SpringBoot中六种批量更新Mysql的方式效率对比分析

《SpringBoot中六种批量更新Mysql的方式效率对比分析》文章比较了MySQL大数据量批量更新的多种方法,指出REPLACEINTO和ONDUPLICATEKEY效率最高但存在数据风险,MyB... 目录效率比较测试结构数据库初始化测试数据批量修改方案第一种 for第二种 case when第三种

Java docx4j高效处理Word文档的实战指南

《Javadocx4j高效处理Word文档的实战指南》对于需要在Java应用程序中生成、修改或处理Word文档的开发者来说,docx4j是一个强大而专业的选择,下面我们就来看看docx4j的具体使用... 目录引言一、环境准备与基础配置1.1 Maven依赖配置1.2 初始化测试类二、增强版文档操作示例2.

一文详解如何使用Java获取PDF页面信息

《一文详解如何使用Java获取PDF页面信息》了解PDF页面属性是我们在处理文档、内容提取、打印设置或页面重组等任务时不可或缺的一环,下面我们就来看看如何使用Java语言获取这些信息吧... 目录引言一、安装和引入PDF处理库引入依赖二、获取 PDF 页数三、获取页面尺寸(宽高)四、获取页面旋转角度五、判断

Spring Boot中的路径变量示例详解

《SpringBoot中的路径变量示例详解》SpringBoot中PathVariable通过@PathVariable注解实现URL参数与方法参数绑定,支持多参数接收、类型转换、可选参数、默认值及... 目录一. 基本用法与参数映射1.路径定义2.参数绑定&nhttp://www.chinasem.cnbs

JAVA中安装多个JDK的方法

《JAVA中安装多个JDK的方法》文章介绍了在Windows系统上安装多个JDK版本的方法,包括下载、安装路径修改、环境变量配置(JAVA_HOME和Path),并说明如何通过调整JAVA_HOME在... 首先去oracle官网下载好两个版本不同的jdk(需要登录Oracle账号,没有可以免费注册)下载完