news 2026/4/23 20:22:34

面试常见问题之剖析哈希表

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
面试常见问题之剖析哈希表


一、时间复杂度基础

- 时间复杂度是衡量算法效率的指标,用大O表示法(如O(1)、O(n)、O(n^2))。数值越小,算法效率越高。
- O(1):无循环的简单操作,如赋值、基本运算、数组下标访问。
- O(n):单层循环操作,时间消耗随n线性增长。
- O(n^2):嵌套双层循环操作,时间消耗随n平方增长。

二、哈希表底层结构与查找效率

- 哈希表底层物理结构是数组,利用数组下标访问的O(1)特性,实现哈希表查找的高效性。

三、哈希存储与哈希函数

- 存储数据时,通过**哈希函数(取模运算)**将数据映射到数组下标。例如数组长度为8时,数字5直接存在下标5的位置;数字8通过8 \% 8 = 0,存在下标0的位置。

四、哈希冲突

- 定义:不同数据经哈希函数映射后得到相同下标,导致冲突。如8、16、32对8取模都得0。
- 解决方法(链地址法):将哈希冲突的元素串联成链表,哈希表升级为链表数组(数组每个元素是链表头指针)。

五、负载因子与Rehash

- 负载因子:公式为 元素个数 / 数组长度 。当负载因子过大(如大于5),哈希表会出现大量长链表,查找效率退化。
- Rehash(重新哈希):数组扩容为原来的2倍,所有元素重新通过哈希函数映射,分散链表元素,避免长链表。
- 渐进式Rehash:避免一次性Rehash导致的性能波动,将Rehash过程分散到程序运行的多个阶段,逐步完成元素重新映射。

六、哈希表长度的优化

- 哈希表长度设计为2的幂,利用**位运算(与运算)**优化取模操作。因为x \% 2^n等价于x \& (2^n - 1),位运算效率高于取模运算。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/18 2:06:16

码农常见问题之如何证明自己写的算法是对的

很多初学者不知道如何证明自己写的算法是正确的,通常只能通过提交代码看是否“AC”(Accepted,即通过所有测试用例)来判断。核心方法(四步验证法)以“在含10万个元素的数组中,找两数之和等于1024…

作者头像 李华
网站建设 2026/4/21 14:52:13

MATH Day 05 Applications amp;amp; Practice

可持久化线段树 (Persistent Segment Tree) 1. 核心思想:共享结构 (Shared Structure) 基本原理:每次修改操作不复制整个结构,而仅创建 \(O(\log n)\) 个新节点。关键技术:动态开点。 每个节点显式存储左右儿子的索引。分配新索…

作者头像 李华
网站建设 2026/4/23 12:17:35

Cortex-M系列,Cortex-A系列,汇编启动文件的区别

Cortex-M系列:可以不自己写汇编启动代码,因为芯片厂商提供了完整的启动文件,但理解汇编对调试和优化很重要。 Cortex-A系列:通常需要懂汇编启动原理,但实际开发中常使用现成的bootloader(如U-Boot&#xf…

作者头像 李华