| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> 数据结构与算法 -> LeetCode - 哈希表专题 -> 正文阅读 |
|
[数据结构与算法]LeetCode - 哈希表专题 |
文章目录前言????????今天算法的内容是: 一、哈希表1. 分类2. 什么情况下要用哈希表?将一个比较庞大的值域映射到一个比较小的区间(区间范围为 0 ~ N)。 例如,操作数的 个数 是105, 操作数值的 范围 是 思想:通过一个哈希函数,函数的输入为 x(-109 ~ 109 值域内的一个数),输出为 0 ~ 105 的一个数,哈希函数的作用是可以将-109 ~ 109 值域内的一个数内 映射 到 0 ~ 105 的一个数。 实现: x ∈ ∈ ∈ (-109 ~ 109 ),h 为哈希函数,h(x) ∈ ∈ ∈ ( 0 ~ 105 )为哈希值,h(x) = x % 105。 哈希冲突:因为 x 的范围大,不同的 x 可能映射成相同的 y,即将若干不一样的数映射成了同一个数,需要处理冲突 。 3. 冲突处理① 拉链法含义通过一个一维数组来存所有的哈希值,每一个位置都看作是一个 槽 ,将值映射到槽上,每一个槽上都拉一条 链,用来存储当前这个槽上已有的所有的数。 操作在算法题中哈希表只有 插入 和 查找 这两个操作,操作的时间复杂度都是 O(1)。 插入一个值 x求 h(x),h(x) 对应的是哪个槽,将 x 插到这个槽对应的链(单链表)上即可。 查找一个值 x求 h(x),看 h(x) 对应的是哪个槽,然后遍历一下这个槽对应的单链表,判断是否存在 x 即可。 ② 开放寻址法含义开一个一维数组,数组的长度为数据范围的 2 ~ 3 倍,h(x) = k,找到第 k 个位置看其是否有数,如果有就跳到下一个位置,直到找到一个没有数的位置将 x 插入。 操作插入一个数 x求 h(x) = k,找到第 k 个位置,然后从第 k 个位置开始往后找,直到找到第一个空的位置为止,然后将 x 插入。 查找一个数 xh(x) = k,找到第 k 个位置,从第 k 个位置开始从前往后找,每一次先看一下当前位置有没有数,如果当前位置没有数说明 x 不存在,如果当前位置有数并且是 x 的话就证明找到了 x,如果当前位置有数但不是 x,那么往后看下一个位置,以此类推直到找到为止。 find 操作为核心操作。find(x),如果 x 在哈希表中已经存在的话,返回 x 所在的位置,如果 x 在哈希表中不存在的话,返回的是 x 应该存储的位置。 哈希表代码实现1. 模拟散列表
二、刷题LeetCode 1748. 唯一元素的和 原题链接
LeetCode 387. 字符串中的第一个唯一字符 原题链接
LeetCode 1941. 检查是否所有字符出现次数相同 原题链接
LeetCode 448. 找到所有数组中消失的数字 原题链接
LeetCode 1512. 好数对的数目 原题链接
|
|
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 | -2024/11/26 4:39:51- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |