【哈希表专题】(1. 两数之和 面试题 01.02. 判定是否互为字符重排 217. 存在重复元素 219. 存在重复元素 II 49. 字母异位词分组)

文章目录

  • 哈希表
    • 1. 两数之和
    • 面试题 01.02. 判定是否互为字符重排
    • 217. 存在重复元素
    • 219. 存在重复元素 II
    • 49. 字母异位词分组


哈希表

哈希表是什么:存储数据的容器

作用:快速查找某个元素。O(1)

当我们需要频繁的查找某一个数的时候,可以使用哈希表。

如何用哈希表

  1. 容器(哈希表)
  2. 用数组模拟简易哈希表
    (字符串中的“字符”)
    (数据范围很小的时候)

1. 两数之和

题目链接: leetcode1. 两数之和

在这里插入图片描述
解法一:暴力解法

  1. 先固定其中一个数
  2. 依次与该数之前的数相加

代码:

class Solution {
    public int[] twoSum(int[] nums, int target) {
        int[] ret = new int[2];
        for (int i = 0; i < nums.length; i++) {
            for (int j = i - 1; j >= 0; j--) {
                if (nums[i] + nums[j] == target) {
                    ret[0] = i;
                    ret[1] = j;
                    return ret;
                }
            }
        }
        return ret;
    }
}

twoSum该方法接收两个参数:一个整数数组nums和一个整数target。方法的目的是在nums数组中找到两个数,使它们的和等于target,并返回这两个数的索引。

解析:

  1. 创建一个长度为2的整数数组ret,用于存储找到的两个数的索引。
  2. 使用两层for循环遍历nums数组。外层循环遍历数组中的每个元素,内层循环从当前元素的前一个元素开始向前遍历。
  3. 如果在内层循环中找到两个数的和等于target,将它们的索引分别存储在ret数组的第0个和第1个位置,并返回ret数组。
  4. 如果遍历完整个数组都没有找到满足条件的两个数,返回ret数组(此时ret数组中的元素未被修改)。

解法二:哈希表

class Solution {
    public int[] twoSum(int[] nums, int target) {
        Map<Integer,Integer> hash = new HashMap<>();
        for(int i = 0; i < nums.length;i++){
            int x = target - nums[i];
            if(hash.containsKey(x)){
                return new int[]{i,hash.get(x)};
            }
            hash.put(nums[i],i);
        }
        return new int[]{-1,-1};
    }
}

twoSum该方法接收两个参数:一个整数数组nums和一个整数target。方法的目的是在nums数组中找到两个数,使它们的和等于target,并返回这两个数的索引。

首先,创建一个HashMap(名为hash)来存储数组中的元素及其对应的索引。然后,遍历数组nums,对于每个元素nums[i],计算target减去nums[i]的值(x)。接着,检查hash中是否包含键x。如果包含,说明找到了两个数的和等于target,返回这两个数的索引(i和hash.get(x))。如果不包含,将当前元素nums[i]及其索引i添加到hash中。

如果遍历完数组后仍未找到满足条件的两个数,返回一个包含两个-1的数组。

面试题 01.02. 判定是否互为字符重排

题目链接: 面试题 01.02. 判定是否互为字符重排

在这里插入图片描述

CheckPermutation该方法接受两个字符串参数s1s2,并返回一个布尔值。

方法的功能是检查两个字符串是否为彼此的排列(permutation)。它首先检查两个字符串的长度是否相等,如果不相等则直接返回false。然后,它创建一个长度为26的整型数组hash,用于记录每个字符出现的次数。

接下来,通过遍历字符串s1,将每个字符对应的位置在hash数组中加一。然后,再遍历字符串s2,将每个字符对应的位置在hash数组中减一。如果在遍历过程中发现某个字符在hash数组中的值小于零,说明该字符在s2中出现的次数超过了在s1中出现的次数,因此返回false

如果遍历完两个字符串后没有发现任何问题,说明两个字符串是彼此的排列,返回true

以下是代码的解析:

class Solution {
    public boolean CheckPermutation(String s1, String s2) {
        if (s1.length() != s2.length()) {
            return false;
        }
        int[] hash = new int[26];
        for (int i = 0; i < s1.length(); i++) {
            hash[s1.charAt(i) - 'a']++;
        }
        for (int i = 0; i < s2.length(); i++) {
            hash[s2.charAt(i) - 'a']--;
            if (hash[s2.charAt(i) - 'a'] < 0) {
                return false;
            }
        }
        return true;
    }
}

217. 存在重复元素

题目链接: 217. 存在重复元素

在这里插入图片描述

class Solution {
    public boolean containsDuplicate(int[] nums) {
        Set<Integer> hash = new HashSet<>();
        for(int s : nums){
            if(hash.contains(s)){
                return true;
            }
            hash.add(s);
        }
        return false;
    }
}

containsDuplicate该方法接受一个整数数组nums作为参数。方法的目的是检查数组中是否存在重复的元素。

代码中使用了一个HashSet来存储已经遍历过的元素。对于数组中的每个元素s,首先检查HashSet中是否已经包含了该元素。如果包含,说明存在重复元素,返回true。如果不包含,将该元素添加到HashSet中。

如果遍历完整个数组后都没有发现重复元素,则返回false

219. 存在重复元素 II

题目链接: 219. 存在重复元素 II

在这里插入图片描述
在这里插入图片描述

class Solution {
    public boolean containsNearbyDuplicate(int[] nums, int k) {
        Map<Integer,Integer> hash = new HashMap<>();
        for(int i = 0; i < nums.length; i++){
            if(hash.containsKey(nums[i])){
                if(i - hash.get(nums[i]) <= k){
                    return true;
                }
            }
            hash.put(nums[i],i);
        }
        return false;
    }
}

这段代码的功能是检查一个整数数组 nums 中是否存在两个相同的元素,且这两个相同元素的索引之间的差值不超过一个给定的整数 k

具体来说,方法 containsNearbyDuplicate 接受两个参数:

  1. int[] nums: 一个整数数组。
  2. int k: 一个非负整数,表示允许的最大索引差。

方法通过使用一个哈希表(在 Java 中是 HashMap)来跟踪每个数字最后出现的位置。算法如下:

  1. 初始化一个空的 HashMap,用于存储数组中的数字及其对应的最新索引。

  2. 遍历数组 nums 中的每个数字 nums[i]

  3. 对于每个数字 nums[i],检查它是否已经在 HashMap 中存在:

    • 如果不存在,将该数字和其索引 i 添加到 HashMap 中。
    • 如果存在,获取该数字之前记录的索引 lastIndex,并计算当前索引 ilastIndex 的差值。
  4. 如果这个差值小于或等于 k,则返回 true,表示找到了两个索引差不超过 k 的相同元素。

  5. 如果遍历完整个数组后没有找到这样的元素对,则返回 false

这个方法可以用于解决一些与数组中重复元素位置有关的问题,例如在滑动窗口内查找重复项等。

49. 字母异位词分组

题目链接: 49. 字母异位词分组

在这里插入图片描述

  1. 算法概述

    • 遍历输入字符串列表。
    • 对于每个字符串:
      • 将其转换为字符数组。
      • 对字符数组进行排序。
      • 创建一个键,将排序后的字符数组转换回字符串。
      • 如果该键尚不存在于映射中,则为该键创建一个新列表。
      • 将原始字符串添加到与该键对应的列表中。
    • 从映射中提取结果,返回值为一组同字母异序词的列表。
  2. 解释

    • 代码使用一个名为 hashMap<String, List<String>> 来存储同字母异序词。
    • 对于每个输入字符串 s
      • s 转换为字符数组(tmp)。
      • 对字符数组进行排序。
      • 创建一个键,将排序后的字符数组转换回字符串。
      • 如果该键尚不存在于映射中,则为该键创建一个新列表。
      • s 添加到与该键对应的列表中。
    • 最后,从映射中返回值(同字母异序词的列表)。
  3. 示例

    • 给定输入:strs = ["eat", "tea", "tan", "ate", "nat", "bat"]
    • 输出:[["bat"], ["nat", "tan"], ["ate", "eat", "tea"]]
  4. 约束条件

    • 1 <= strs.length <= 10^4
    • 0 <= strs[i].length <= 100
    • strs[i] 由小写英文字母组成。
  5. 判断两个字符串是否是字母异位词

  6. 分组

在这里插入图片描述
在这里插入图片描述

class Solution {
    public List<List<String>> groupAnagrams(String[] strs) {
        Map<String,List<String>> hash = new HashMap<>();
        // 1.把所有的字符异位词分组
        for(String s : strs){
            char[] tmp = s.toCharArray();
            Arrays.sort(tmp);
            String key = new String(tmp);
            if(!hash.containsKey(key)){
                hash.put(key,new ArrayList());
            }
            hash.get(key).add(s);
        }
        //2. 提取结果
        return new ArrayList(hash.values());
    }
}

代码解释:

1. 定义类和方法:

class Solution {  
    public List<List<String>> groupAnagrams(String[] strs) {

这里定义了一个名为Solution的类,并在其中定义了一个名为groupAnagrams的公共方法,该方法接受一个字符串数组strs作为参数,并返回一个二维列表,其中每个内部列表都包含一组字符异位词。
2. 初始化哈希表:

Map<String,List<String>> hash = new HashMap<>();

使用Java的HashMap数据结构来存储分组。其中键(key)是排序后的字符串,值(value)是一个列表,包含所有与该键对应的原始字符串(即字符异位词)。

3. 分组字符异位词:

for(String s : strs){  
    char[] tmp = s.toCharArray();  
    Arrays.sort(tmp);  
    String key = new String(tmp);  
    if(!hash.containsKey(key)){  
        hash.put(key,new ArrayList());  
    }  
    hash.get(key).add(s);  
}

对于strs数组中的每个字符串s:

  • 首先,将字符串转换为字符数组tmp
  • 然后,对字符数组进行排序,以消除字符顺序的影响。
  • 接着,将排序后的字符数组转换回字符串,作为哈希表的键(key)。
  • 如果哈希表中还没有这个键,则创建一个新的空列表作为值,并将其添加到哈希表中。
  • 最后,将原始字符串s添加到与该键对应的列表中。

4. 提取结果:

return new ArrayList(hash.values());

将哈希表中的所有值(即所有字符异位词的列表)提取出来,并放入一个新的列表中。这个新列表就是最终的结果,它包含了所有分组后的字符异位词。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

YOLO火灾烟雾检测数据集:20000多张,yolo标注完整

YOLO火灾烟雾检测数据集&#xff1a;一共20859张图像&#xff0c;yolo标注完整&#xff0c;部分图像应用增强 适用于CV项目&#xff0c;毕设&#xff0c;科研&#xff0c;实验等 需要此数据集或其他任何数据集请私信

蓝桥杯备考2

P8839 [传智杯 #4 初赛] 组原成绩 题目描述 花栗鼠科技大学&#xff08;Hualishu University of Science and Technology, HUST&#xff09;的计算机组成原理快要出分了。你现在需要计算你的组原成绩如何构成。 具体来说&#xff0c;组原成绩分为三部分&#xff0c;分别是平…

算法学习系列(四十六):迭代加深、双向DFS

目录 引言概念一、加成序列二、送礼物 引言 本文主要讲了&#xff0c; D F S DFS DFS 的另外两种优化&#xff0c;分别是迭代加深和双向 D F S DFS DFS &#xff0c;思路还是非常清晰明了的&#xff0c;只要会写 D F S DFS DFS 那么这些剪枝和优化其实还是非常的容易的&…

多线程学习-线程安全

目录 1.多线程可能会造成的安全问题 2. static共享变量 3.同步代码块 4.同步方法 5.使用Lock手动加锁和解锁 6.死锁 1.多线程可能会造成的安全问题 场景&#xff1a;三个窗口同时售卖100张电影票&#xff0c;使用线程模拟。 public class MyThread extends Thread{//tic…

AI结合机器人的入门级仿真环境有哪些?

由于使用真实的机器人开发和测试应用程序既昂贵又费时&#xff0c;因此仿真已成为机器人应用程序开发中越来越重要的部分。在部署到机器人之前在仿真中验证应用程序可以通过尽早发现潜在问题来缩短迭代时间。通过模拟&#xff0c;还可以更轻松地测试在现实世界中可能过于危险的…

Linux文件搜索工具(gnome-search-tool)

opensuse下安装: sudo zypper install gnome-search-tool 操作界面:

【剑指offr--C/C++】JZ59 滑动窗口的最大值

一、题目 二、思路及代码 暴力解法是依次往后滑动一位&#xff0c;然后比较窗口内的值。 我这里考虑&#xff1a;窗口每次往后移动一位&#xff0c;那么如果当前窗口的最大值max在窗口内部&#xff0c;那么再滑动到下一个窗口的时候&#xff0c;窗口内只有最新进来的一个元素没…

解决:CloudCompare中display选择Full screen后无法恢复且无法关闭

问题 在CloudCompare中display选择Full screen进行全屏显示时&#xff0c;软件各按钮失效且软件无法关闭 解决 按下F9键退出全屏模式&#xff0c;笔记本电脑可能需要FnF9同时按下。

算法 - 符号表-下

&#x1f600;前言 推荐从上看到下 算法 - 符号表-上 &#x1f3e0;个人主页&#xff1a;尘觉主页 文章目录 算法 - 符号表查找树1. 插入操作2. 性质 红黑树1. 左旋转2. 右旋转3. 颜色转换4. 插入5. 分析 散列表1. 散列函数2. 拉链法3. 线性探测法3.1 查找3.2 插入3.3 删除3.5 …

中兴天机A31 A31PRO 5G zte A2122H te A2022H 解锁BootLoader root权限 教程magisk,原厂刷机包

zte A2122H P768A02 zte A2022H P875A02 中兴天机A31 A31PRO 5G zte A2122H te A2022H 解锁BootLoader root教程magisk&#xff0c;原厂刷机包 感谢 某大神支持&#xff0c;已经解锁root 刷了面具&#xff1b; 中兴天机A31 A31PRO 5G zte A2122H te A2022H 解锁BootLoad…

Oracle 数据库中的全文搜索

Oracle 数据库中的全文搜索 0. 引言1. 整体流程2. 创建索引2-1. 创建一个简单的表2-2. 创建文本索引2-3. 查看创建的基础表 3. 运行查询3-1. 运行文本查询3-2. CONTAINS 运算符3-3. 混合查询3-4. OR 查询3-5. 通配符3-6. 短语搜索3-7. 模糊搜索&#xff08;Fuzzy searches&…

Francek Chen 的128天创作纪念日

目录 Francek Chen 的128天创作纪念日机缘收获日常成就憧憬 Francek Chen 的128天创作纪念日 Francek Chen 的个人主页 机缘 不知不觉的加入CSDN已有两年时间了&#xff0c;最初我第一次接触CSDN技术社区是在2022年4月的时候&#xff0c;通过学长给我们推荐了几个IT社区平台&a…

代码随想录-力扣刷题-总结笔记02

代码随想录&#xff1a;代码随想录力扣&#xff1a;力扣 (LeetCode) 全球极客挚爱的技术成长平台 代码随想录-力扣刷题-总结笔记01代码随想录-力扣刷题-总结笔记02 目录 01、代码随想录 00、其他 ArrayList转数组 07、二叉树 7.0、递归法 7.1、二叉树的层序遍历模板 7.2…

Lan仿朋友圈系统开源源码 表白墙 打造朋友圈工具 仿朋友圈界面 朋友圈模拟器在线

(购买本专栏可免费下载栏目内所有资源不受限制,持续发布中,需要注意的是,本专栏为批量下载专用,并无法保证某款源码或者插件绝对可用,介意不要购买!购买本专栏住如有什么源码需要,可向博主私信,第二天即可发布!博主有几万资源) Lan仿朋友圈系统开源,可用于表白墙等…

STL中各类容器详细介绍

STL介绍 STL&#xff08;Standard Template Library&#xff09;&#xff0c;即标准模板库&#xff0c;是一个具有工业强度的&#xff0c;高效的C程序库。它被容纳于C标准程序库&#xff08;C Standard Library&#xff09;中&#xff0c;是ANSI/ISO C标准中最新的也是极具革命…

tsv、csv、xls等文件类型区别及处理(python版)

目录 前言 介绍 tsv、csv、txt的区别 读取/生成 不同格式数据文件&#xff08;python&#xff09; 一、读取/生成csv数据文件 二、读取/生成txt数据文件 三、读取/生成tsv数据文件 四、读取/生成xls数据文件 不同文件格式转化 总结 前言 考虑到进行机器学习、深度学习…

代码随想录day35--动态规划的应用2||01背包理论基础、携带研究材料

01背包理论基础 有n件物品和一个最多能背重量为w的背包。第i件物品的重量是weight[i],得到的价值为 value[i]。每件物品只能用一次&#xff0c;将这些物品装入背包里物品价值总和最大。 这是很标准的背包问题&#xff0c;很多同学看到后很自然的就想到了背包&#xff0c;我们…

【Linux学习】Linux 的虚拟化和容器化技术

˃͈꒵˂͈꒱ write in front ꒰˃͈꒵˂͈꒱ ʕ̯•͡˔•̯᷅ʔ大家好&#xff0c;我是xiaoxie.希望你看完之后,有不足之处请多多谅解&#xff0c;让我们一起共同进步૮₍❀ᴗ͈ . ᴗ͈ აxiaoxieʕ̯•͡˔•̯᷅ʔ—CSDN博客 本文由xiaoxieʕ̯•͡˔•̯᷅ʔ 原创 CSDN 如…

少儿编程 2024年3月电子学会图形化编程等级考试Scratch一级真题解析(选择题)

2024年3月scratch编程等级考试一级真题 选择题&#xff08;共25题&#xff0c;每题2分&#xff0c;共50分&#xff09; 1、单击下列哪个按钮&#xff0c;能够让舞台变为“全屏模式” A、 B、 C、 D、 答案&#xff1a;C 考点分析&#xff1a;考查scratch平台的使用&…

java中Date类,SimpleDateFormat类和Calendar类

Date类 public Date() 创建一个Date对象&#xff0c;代表的是系统当前此刻的日期时间 public Date(long date) Constructs a Date object using the given milliseconds time value. 把时间毫秒值转变成Date日期对象 public void setTime(long date) Sets an existing Date ob…