Java高频面试之集合-15

hello啊,各位观众姥爷们!!!本baby今天来报道了!哈哈哈哈哈嗝🐶

面试官:解决哈希冲突有哪些方法?


1. 开放寻址法(Open Addressing)

核心思想:当哈希冲突发生时,通过特定规则探测下一个空闲槽位存储数据。

方法分类
  • 线性探测(Linear Probing)

    • 规则:冲突后顺序查找下一个槽位,公式:(hash(key) + i) % sizei为步长,初始为1,逐步递增)。
    • 优点:实现简单,无需额外数据结构。
    • 缺点:易产生聚集(Clustering),导致查找效率降低。
  • 二次探测(Quadratic Probing)

    • 规则:冲突后按二次方步长探测,公式:(hash(key) + i²) % size
    • 优点:减少聚集现象。
    • 缺点:可能导致二次聚集,且需保证哈希表大小为质数以覆盖所有槽位。
  • 双重哈希(Double Hashing)

    • 规则:使用第二个哈希函数计算步长,公式:(hash1(key) + i * hash2(key)) % size
    • 优点:探测序列分散,减少聚集。
    • 缺点:需设计两个独立哈希函数。

适用场景:内存敏感场景(如嵌入式系统),无需额外存储指针。


2. 链地址法(Chaining)

核心思想:每个哈希槽位维护一个链表(或树),冲突元素追加到同一槽位的链表中。

实现方式
  • 链表(LinkedList)

    • 操作:冲突元素插入链表尾部,查找需遍历链表。
    • 优点:实现简单,动态扩展。
    • 缺点:链表过长时查找退化为O(n)。
  • 红黑树(Java HashMap优化)

    • 规则:链表长度超过阈值(如8)时,转为红黑树,查找效率提升至O(log n)。
    • 优点:平衡查找效率与内存开销。
    • 缺点:树结构维护复杂度高。

适用场景:通用场景(如Java HashMap),适合频繁插入和删除。


3. 再哈希法(Rehashing)

核心思想:使用多个哈希函数,冲突时按顺序尝试不同哈希函数,直到找到空槽。

  • 优点:减少冲突概率。
  • 缺点:需设计多个高效哈希函数,实现复杂。
  • 典型应用:分布式系统的一致性哈希。

4. 建立公共溢出区(Overflow Area)

核心思想:将哈希表分为主表和溢出表,冲突元素存入溢出表。

  • 优点:主表结构清晰,实现简单。
  • 缺点:溢出表可能成为性能瓶颈。
  • 适用场景:小型哈希表或固定数据集。

5. 完美哈希(Perfect Hashing)

核心思想:通过特殊构造的哈希函数,确保静态数据集无冲突。

  • 优点:查找时间复杂度严格O(1)。
  • 缺点:构造复杂,仅适用于静态数据(如编译器符号表)。
  • 实现方式:两级哈希表,第一级哈希到桶,第二级桶内无冲突。

6. 动态扩容(Dynamic Resizing)

核心思想:当负载因子(元素数/容量)超过阈值时,扩容哈希表并重新哈希所有元素。

  • 扩容策略:容量通常翻倍(如Java HashMap)。
  • 优点:降低冲突概率,维持高效操作。
  • 缺点:扩容耗时,需重新哈希所有元素。

方法对比与选型建议

方法时间复杂度空间复杂度适用场景
开放寻址法平均O(1),最差O(n)内存敏感,低负载场景
链地址法平均O(1),最差O(n)中(指针开销)通用场景,高冲突容忍
再哈希法平均O(1)需要高哈希函数设计
公共溢出区平均O(1),最差O(n)小型或静态数据集
完美哈希O(1)静态数据集(如字典、符号表)
动态扩容分摊O(1)动态数据集,需平衡负载因子

🐮🐎

  • 开放寻址法:适合内存紧凑场景,但需处理聚集问题。
  • 链地址法:灵活通用,结合红黑树优化后适合高并发场景。
  • 完美哈希:静态数据集的最佳选择,但构造复杂。
  • 动态扩容:维持低负载因子,是多数现代哈希表的基础机制。

实际应用示例

  • Java HashMap:链地址法 + 动态扩容 + 红黑树优化。
  • Redis Hash:链地址法 + 渐进式扩容。

在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【机器学习】建模流程

1、数据获取 1.1 来源 数据获取是机器学习建模的第一步,常见的数据来源包括数据库、API、网络爬虫等。 数据库是企业内部常见的数据存储方式,例如:MySQL、Oracle等关系型数据库,以及MongoDB等非关系型数据库,它们能够…

GitHub 上的 Khoj 项目:打造你的专属 AI 第二大脑

在信息爆炸的时代,高效管理和利用个人知识变得愈发重要。GitHub 上的 Khoj 项目为我们提供了一个强大的解决方案,它能成为你的 “AI 第二大脑”,帮你轻松整合、搜索和运用知识。今天,就来详细了解下 Khoj。​ Khoj 是什么&#x…

爬虫(requsets)笔记

一、request_基本使用 pip install requests -i https://pypi.douban.com/simple 一个类型六个属性 r.text 获取网站源码 r.encoding 访问或定制编码方式r.url 获取请求的urlr.content 响应的字节类型r.status_code 响应的状态码r.headers 响应的头信息 import requestsur…

centos7连不上接网络

选择编辑, 选择虚拟机网络编辑 右键虚拟机,点击设置,设置网络,选择nat模式, 配置:/etc/sysconfig/network-scripts/ifcfg-ens33 vim /etc/sysconfig/network-scripts/ifcfg-ens33设置IP地址如图所示,重…

OpenResty(Lua)+Redis实现动态封禁IP

文章目录 架构设计环境准备源码编辑安装OpenResty下载安装准备依赖编译安装配置环境变量(可选)OpenResty 服务管理命令 安装Redis配置Lua脚本测试准备测试工具测试封禁逻辑 删除版本信息清除编译安装的OpenResty 架构设计 通过 Nginx Redis 的方案&…

Turtle基本操作(前进、后退、旋转)

1. Turtle基本移动概念 在Turtle绘图中,“海龟”(Turtle)相当于一支笔,它在屏幕上移动时,会在经过的路径上留下轨迹。我们可以通过一系列简单的指令控制它的前进、后退和旋转,从而绘制各种形状和图案。 2. 前进与后退 2.1 前进(forward() 或 fd()) Turtle的 forward…

C++类与对象的第一个简单的实战练习-3.24笔记

在哔哩哔哩学习的这个老师的C面向对象高级语言程序设计教程&#xff08;118集全&#xff09;讲的真的很不错 实战一&#xff1a; 情况一&#xff1a;将所有代码写到一个文件main.cpp中 #include<iostream> //不知道包含strcpy的头文件名称是什么,问ai可知 #include<…

Jetson Orin NX使用 Ollama 本地部署 deepseek

本文记录在 jetson orin nx 上使用 ollama 部署 deepseek 的过程 有用的网站及工具 NVIDIA Jetson AI LabOllama官网Jtop 工具 > 用以查看jetson GPU/CPU/Memory 等占用情况的工具&#xff0c;安装过程如下&#xff1a; sudo apt-get install python3-pip sudo -H pip3 in…

目标检测20年(三)

对这篇论文感兴趣的小伙伴可以订阅笔者《目标检测》专栏&#xff0c;关注笔者对该文献的阅读和理解。 前两篇解读链接&#xff1a; 目标检测20年&#xff08;一&#xff09;-CSDN博客 目标检测20年&#xff08;二&#xff09;-CSDN博客 目录 四、 检测器的加速发展 4.1 特…

智能手持终端PDA在设备巡检管理中的应用

在工业制造、能源电力、轨道交通等领域&#xff0c;设备巡检是保障生产安全与连续性的核心环节。传统巡检模式存在效率低、易出错、数据滞后等痛点。上海岳冉智能设备巡检手持终端PDA&#xff0c;以智能化、数字化、高可靠为核心设计理念&#xff0c;集RFID、条码扫描、AI图像识…

AI知识补全(二):提示工程(Prompting)是什么?

名人说&#xff1a;人生如逆旅&#xff0c;我亦是行人。 ——苏轼《临江仙送钱穆父》 创作者&#xff1a;Code_流苏(CSDN)&#xff08;一个喜欢古诗词和编程的Coder&#x1f60a;&#xff09; 上一篇&#xff1a;AI知识补全&#xff08;一&#xff09;&#xff1a;tokens是什么…

C++友元:跨墙访问的三种姿势

目录 友元 友元之普通函数形式 友元之成员函数形式 友元类 友元的特点 友元 什么叫友元&#xff1f; 一般来说&#xff0c;类的私有成员只能在类的内部访问&#xff0c;类之外是不能访问它们的。但如果将其他类/函数设置为类的友元&#xff0c;那么友元类/函数就可以在前…

位运算[找出唯一成对的数]

题目来源&#xff1a;蓝桥云课 不用辅助储存空间 import java.util.Random;public class T_01 {public class Util {public static void swap(int[] arr, int i, int j) {int temp arr[i];arr[i] arr[j];arr[j] temp;}public static void print(int[] arr) {for (int i 0; …

简记_FPGA 硬件最小系统设计

一、FPGA板级设计的五要素 1.1、电源电路 核心电压&#xff1a;一般为固定值 IO电压&#xff1a;FPGA的IO分为多个bank&#xff0c;同一个bank的不同IO引脚电压相同&#xff0c;不同bank的电压可以不同 辅助电压&#xff1a;除了核心电压和IO电压&#xff0c;FPGA工作所需的…

7.2 控件和组件

版权声明&#xff1a;本文为博主原创文章&#xff0c;转载请在显著位置标明本文出处以及作者网名&#xff0c;未经作者允许不得用于商业目的 C#工具箱位于编辑窗口的左侧&#xff0c;它默认内置了大量的控件和组件。控件一般派生于System.Windows.Forms.Control类&#xff0c;显…

Spring Boot中接口数据字段为 Long 类型时,前端number精度丢失问题解决方案

Spring Boot中接口数据字段为 Long 类型时&#xff0c;前端number精度丢失问题解决方案 在Spring Boot中&#xff0c;当接口数据字段为 Long 类型时&#xff0c;返回页面的JSON中该字段通常会被序列化为数字类型。 例如&#xff0c;一个Java对象中有一个 Long 类型的属性 id …

OpenCV第2课 OpenCV的组成结构与图片/视频的加载及展示

1.OpenCV 的组成结构 2.OpenCV 的具体模块 3. 图像的读取 4. 视频的读取 1.OpenCV 的组成结构 OpenCV 是由很多模块组成的,这些模块可以分成很多层: 最底层是基于硬件加速层(HAL)的各种硬件优化。再上一层是opencv_contrib 模块所包含的OpenCV 由其他开发人员所贡献的代…

安装配置Tesseract-OCR

1,下载对应的可执行文件 在Tesseract OCR下载地址Index of /tesseract下载合适的版本安装包,如下: 点击安装包进行安装: 语言选择英文: 如果需要识别中文,则可以在安装过程中勾选下载中文语言包和脚本(也可以按需选择繁体):

关于墙面涂鸦的视觉检测与喷涂修复装置研究(大纲)

公共场所墙面涂鸦视觉检测与精准喷涂修复装置研究 融合视觉识别与自动化喷涂的墙面维护解决方案 第一章 绪论 1.1 研究背景与意义 城市形象与秩序维护&#xff1a; 涂鸦对公共环境的影响&#xff08;破坏美观、传递不良信息&#xff09;清除涂鸦的重要性&#xff08;恢复原貌…

图论 | 98. 所有可达路径

98. 所有可达路径 题目链接&#xff1a; 98. 所有可达路径 思路 先创建邻接矩阵&#xff0c;再深搜写代码是需要注意的是acm格式&#xff0c;输入的格式要转化为int&#xff0c;输出要转化为str&#xff0c;用map&#xff08;&#xff09;实现。 dfs def dfs(grid,node,n,…