算法系列--哈希表

简介: 算法系列--哈希表

💕"白昼之光,岂知夜色之深。"💕

作者:Mylvzi

文章主要内容:算法系列–哈希表

今天为大家带来的是算法系列--哈希表

1.两数之和

链接:

https://leetcode.cn/problems/two-sum/submissions/515941642/

分析:

有人相爱,有人夜里开车看海,有人leetcode第一题都做不出来。

最容易想到的思路就是暴力解法,每遍历到一个数字,就去从头遍历看有没有相加符合条件的数字,但是这样的时间复杂度达到了O(N^2),使用哈希表可以降低到O(N)

之所以是n^2是因为我么在查找第二个数的时候又套了一层for循环,既然涉及到在一堆数中快速查找某一个数,就可以使用hash表进行优化,思路如下:

  • 每遍历到一个数,就将其数值和下标存入到哈希表之中
  • 判断哈希表中是否存在target-nums[i]的数字,如果有返回这两个数的下标,如果没有继续遍历

代码:

class Solution {
    public int[] twoSum(int[] nums, int target) {
        // 使用哈希表建立数字与下标之间的映射关系
        Map<Integer,Integer> map = new HashMap<>();
        for (int i = 0; i < nums.length; i++) {
            // 去看是否包含target-i
            if(map.containsKey(target-nums[i])) {
                return new int[]{map.get((target-nums[i])),i};// 返回下标
            }
            
            map.put(nums[i],i);
        }
        
        return null;
    }
}

2.判断是否互为字符重排

链接:

https://leetcode.cn/problems/check-permutation-lcci/description/

分析:

本题最直观的想法就是创建出两个哈希表,分别存储字符串中的所有内容,最后判断两个哈希表是否相同即可

代码:

class Solution {
    public boolean CheckPermutation(String s1, String s2) {
        if(s1.length() != s2.length()) return false;
        Map<Character,Integer> hash1 = new HashMap<>();
        Map<Character,Integer> hash2 = new HashMap<>();
        for(char c1 : s1.toCharArray()) {
            hash1.put(c1,hash1.getOrDefault(c1,0) + 1);
        }
        for(char c2 : s2.toCharArray()) {
            hash2.put(c2,hash2.getOrDefault(c2,0) + 1);
        }
        return hash1.equals(hash2);
    }
}

注意本题还可以使用排序的思想,将两个字符串进行排序,然后直接判断是否相同即可

class Solution {
    public boolean CheckPermutation(String s1, String s2) {
        if (s1.length() != s2.length()) return false;
        char[] ss1 = s1.toCharArray();
        char[] ss2 = s2.toCharArray();
        Arrays.sort(ss1);
        Arrays.sort(ss2);
        return Arrays.equals(ss1, ss2);
    }
}

只有使用Arrays.equals()这个方法才能判断数组中的内容是否相同,因为里面重写了equals方法,如果直接比较,比较的是地址

3.存在重复元素 I

链接:

https://leetcode.cn/problems/contains-duplicate/description/

分析:

使用set来判断是否出现重复元素

代码:

class Solution {
    public boolean containsDuplicate(int[] nums) {
        Set<Integer> set = new HashSet<>();
        for(int n : nums) {// add()的返回值是布尔类型
            if(!set.add(n)) return true;
        }
        return false;
    }
}

注意: add()的返回值是布尔类型,用于表示此次添加是否成功.set具有去重的功能,如果添加的元素已经存在,就会添加失败

4.存在重复元素 II

链接:

https://leetcode.cn/problems/two-sum/submissions/515941642/https://leetcode.cn/problems/contains-duplicate-ii/description/

分析:

结合题意解决即可

代码:

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]) && Math.abs(hash.get(nums[i]) - i) <= k) 
                return true;
            hash.put(nums[i],i);
        }
        
        return false;
    }
}

5.字⺟异位词分组

链接:

https://leetcode.cn/problems/group-anagrams/description/

分析:

本题更像是一道语法题,充分利用了java 的Map容器,相同的字母异位词指的是两个字符串中所包含的字符完全相等,也就是将他们按照ascii码值排序之后得到的结果完全相同,我们设这个排序之后的结果为pivot,那么我们就可以利用哈希表建立<pivot,List<String>>之间的映射关系

  • 对字符串进行排序,得到其pivot
  • 如果哈希表中不存在pivot,就新创建一个;如果存在,得到pivot对应的list,让其添加当前的字符串

代码:

class Solution {
    public List<List<String>> groupAnagrams(String[] strs) {
        Map<String,List<String>> hash = new HashMap<>();
        // 先对所有的字符串进行异或分组
        for(String str : strs) {
            char[] tmp = str.toCharArray();
            Arrays.sort(tmp);// 排序  得到pivot
            String key = new String(tmp);// 转化为字符串
            
            List<String> list = hash.getOrDefault(key, new ArrayList<String>());// 注意有可能不存在
            list.add(str);// 添加上当前的字符串
            hash.put(key,list);// 插入哈希表
        }
        
        return new ArrayList(hash.values());// 注意这个语法!可以直接返回hash的所有value的集合
    }
}

总结:

哈希表的使用场景

  1. 快速的寻找某一个元素
  2. 记录出现的次数

哈希表的优化:

  • 使用数组来模拟哈希表,往往出现在数据量较小的时候,省去了new()和方法调用的时间


目录
相关文章
|
算法
带你读《图解算法小抄》六、哈希表(2)
带你读《图解算法小抄》六、哈希表(2)
|
3月前
|
算法 Java 数据库
数据结构与算法学习十五:哈希表
这篇文章详细介绍了哈希表的概念、应用实例、实现思路,并提供了使用Java实现的哈希表代码。
75 0
数据结构与算法学习十五:哈希表
|
4天前
|
存储 监控 JavaScript
深度探秘:运用 Node.js 哈希表算法剖析员工工作时间玩游戏现象
在现代企业运营中,确保员工工作时间高效专注至关重要。为应对员工工作时间玩游戏的问题,本文聚焦Node.js环境下的哈希表算法,展示其如何通过快速查找和高效记录员工游戏行为,帮助企业精准监测与分析,遏制此类现象。哈希表以IP地址等为键,存储游戏网址、时长等信息,结合冲突处理与动态更新机制,确保数据完整性和时效性,助力企业管理层优化工作效率。
16 3
|
3天前
|
存储 算法 安全
基于哈希表的文件共享平台 C++ 算法实现与分析
在数字化时代,文件共享平台不可或缺。本文探讨哈希表在文件共享中的应用,包括原理、优势及C++实现。哈希表通过键值对快速访问文件元数据(如文件名、大小、位置等),查找时间复杂度为O(1),显著提升查找速度和用户体验。代码示例展示了文件上传和搜索功能,实际应用中需解决哈希冲突、动态扩容和线程安全等问题,以优化性能。
|
9天前
|
存储 监控 算法
企业内网监控系统中基于哈希表的 C# 算法解析
在企业内网监控系统中,哈希表作为一种高效的数据结构,能够快速处理大量网络连接和用户操作记录,确保网络安全与效率。通过C#代码示例展示了如何使用哈希表存储和管理用户的登录时间、访问IP及操作行为等信息,实现快速的查找、插入和删除操作。哈希表的应用显著提升了系统的实时性和准确性,尽管存在哈希冲突等问题,但通过合理设计哈希函数和冲突解决策略,可以确保系统稳定运行,为企业提供有力的安全保障。
|
12天前
|
存储 缓存 算法
探索企业文件管理软件:Python中的哈希表算法应用
企业文件管理软件依赖哈希表实现高效的数据管理和安全保障。哈希表通过键值映射,提供平均O(1)时间复杂度的快速访问,适用于海量文件处理。在Python中,字典类型基于哈希表实现,可用于管理文件元数据、缓存机制、版本控制及快速搜索等功能,极大提升工作效率和数据安全性。
46 0
|
8月前
|
存储 算法 Java
【算法系列篇】哈希表
【算法系列篇】哈希表
|
7月前
|
存储 算法 数据可视化
【漫画算法】哈希表:古代皇帝的秘密魔法书
【漫画算法】哈希表:古代皇帝的秘密魔法书
|
7月前
|
存储 算法 Java
面试高频算法题汇总「图文解析 + 教学视频 + 范例代码」之 二分 + 哈希表 + 堆 + 优先队列 合集
面试高频算法题汇总「图文解析 + 教学视频 + 范例代码」之 二分 + 哈希表 + 堆 + 优先队列 合集
|
7月前
|
存储 算法
数据结构和算法——了解哈希表(哈希查找、散列的基本思想)
数据结构和算法——了解哈希表(哈希查找、散列的基本思想)
60 0

热门文章

最新文章