Java数据结构与算法(散列表)

前言

散列表是根据关键码值(Key value)而直接进行访问的数据结构。也就是说,它通过把关键码值映射到表中一个位置来访问记录,以加快查找的速度。而key的冲突主要通过链表的方式来处理,后期链表过长情况下可以通过红黑树来优化查询效率。

实现原理

  1. 散列函数(Hash Function): 散列函数用于将输入的键转换为表中的索引。理想的散列函数应当将键均匀地分布到表的各个位置,以减少冲突。散列函数的一些常见实现包括将键的ASCII值进行某种数学运算或使用更复杂的算法,如SHA-256。

  2. 冲突(Collision): 当两个不同的键通过散列函数映射到相同的位置时,就会发生冲突。处理冲突是散列表实现中的一个关键问题。

动画过程

Open Hashing Visualization

具体代码实现

import java.util.LinkedList;public class HashTable<K, V> {// Node class to store key-value pairsprivate static class Node<K, V> {K key;V value;Node(K key, V value) {this.key = key;this.value = value;}}// Default size of the hash tableprivate static final int DEFAULT_SIZE = 16;// Array of linked lists to store the chainsprivate LinkedList<Node<K, V>>[] table;// Current size of the hash tableprivate int size;// Constructor to initialize the hash table with default size@SuppressWarnings("unchecked")public HashTable() {table = new LinkedList[DEFAULT_SIZE];size = 0;}// Hash function to compute index for a keyprivate int hash(K key) {return Math.abs(key.hashCode() % table.length);}// Method to insert a key-value pair into the hash tablepublic void insert(K key, V value) {int index = hash(key);if (table[index] == null) {table[index] = new LinkedList<>();}// Check if the key already exists, update value if it doesfor (Node<K, V> node : table[index]) {if (node.key.equals(key)) {node.value = value;return;}}// If key does not exist, add a new node to the chaintable[index].add(new Node<>(key, value));size++;}// Method to retrieve a value by its keypublic V get(K key) {int index = hash(key);if (table[index] == null) {return null;}// Search for the key in the chainfor (Node<K, V> node : table[index]) {if (node.key.equals(key)) {return node.value;}}// If key is not found, return nullreturn null;}// Method to delete a key-value pair from the hash tablepublic boolean delete(K key) {int index = hash(key);if (table[index] == null) {return false;}// Search for the key in the chain and remove itfor (Node<K, V> node : table[index]) {if (node.key.equals(key)) {table[index].remove(node);size--;return true;}}return false;}// Method to get the current size of the hash tablepublic int size() {return size;}// Method to check if the hash table is emptypublic boolean isEmpty() {return size == 0;}// Main method for testingpublic static void main(String[] args) {HashTable<String, Integer> hashTable = new HashTable<>();hashTable.insert("apple", 1);hashTable.insert("banana", 2);hashTable.insert("cherry", 3);System.out.println("Value for 'apple': " + hashTable.get("apple"));System.out.println("Value for 'banana': " + hashTable.get("banana"));System.out.println("Value for 'cherry': " + hashTable.get("cherry"));hashTable.delete("banana");System.out.println("Value for 'banana' after deletion: " + hashTable.get("banana"));System.out.println("Current size: " + hashTable.size());}
}

QA:待定

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

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

相关文章

进程互斥经典问题(读写者问题、理发店问题)

目录 读写者问题 问题描述 问题分析 进程互斥问题三部曲 读者写者算法实现 一、找进程——确定进程关系 二、找主营业务 三、找同步约束 a.互斥 b.资源 c.配额 理发店问题 问题描述 问题分析 进程互斥问题三部曲 理发店问题算法实现 一、找进程——确定进程…

SB-OSC,最新的 MySQL Schema 在线变更方案

目前主流的 MySQL 在线变更方案有两个&#xff1a; 基于 trigger 的 pt-online-schema-change基于 binlog 的 gh-ost 上周 Sendbird 刚开源了他们的 MySQL Schema 在线变更方案 SB-OSC: Sendbird Online Schema Change。 GitHub 上刚刚 25 颗星星&#xff0c;绝对新鲜出炉。 …

Qt Creator(2)【如何在Qt Creator中创建新工程】

阅读导航 引言一、Qt Creator开始界面介绍二、如何在Qt Creator中创建新工程1. 新建项目2. 选择项目模板3. 选择项目路径4. 选择构建系统5. 填写类信息设置界面6. 选择语言和翻译文件7. 选择Qt套件8. 选择版本控制系统9. 最终效果 三、认识Qt Creator项目内容界面1. 基本界面2.…

React Native 之 处理触摸事件(八)

React Native 提供了可以处理常见触摸手势&#xff08;例如点击或滑动&#xff09;的组件&#xff0c; 以及可用于识别更复杂的手势的完整的手势响应系统。 Button是一个简单的跨平台的按钮组件。下面是一个最简示例&#xff1a; <ButtononPress{() > {Alert.alert(你点…

go语言初识别(五)

本博客内容涉及到&#xff1a;切片 切片 1. 切片的概念 首先先对数组进行一下回顾&#xff1a; 数组定义完&#xff0c;长度是固定的&#xff0c;例如&#xff1a; var num [5]int [5]int{1,2,3,4,5}定义的num数组长度是5&#xff0c;表示只能存储5个整形数字&#xff0c…

检索模型预训练方法:RetroMAE

论文title&#xff1a;https://arxiv.org/pdf/2205.12035RetroMAE: Pre-Training Retrieval-oriented Language Models Via Masked Auto-Encoder 论文链接&#xff1a;https://arxiv.org/pdf/2205.12035 摘要 1.一种新的MAE工作流&#xff0c;编码器和解器输入进行了不同的掩…

华为OD机试【计算最接近的数】(java)(100分)

1、题目描述 给定一个数组X和正整数K&#xff0c;请找出使表达式X[i] - X[i1] … - X[i K 1]&#xff0c;结果最接近于数组中位数的下标i&#xff0c;如果有多个i满足条件&#xff0c;请返回最大的i。 其中&#xff0c;数组中位数&#xff1a;长度为N的数组&#xff0c;按照元…

软件性能测试有哪些测试类型和方法?

软件性能测试是一种通过模拟真实用户使用情况&#xff0c;评估软件系统在各种压力和负载下的表现的测试方法。在今天这个讲究效率的时代&#xff0c;软件性能测试是不可或缺的一环。它能帮助开发人员和企业发现潜在的性能问题&#xff0c;提前优化改进&#xff0c;保证软件系统…

Flutter 中的 SizeChangedLayoutNotifier 小部件:全面指南

Flutter 中的 SizeChangedLayoutNotifier 小部件&#xff1a;全面指南 在 Flutter 中&#xff0c;SizeChangedLayoutNotifier 是一种特殊的小部件&#xff0c;它用于监听其子组件尺寸的变化。当子组件的大小发生变化时&#xff0c;SizeChangedLayoutNotifier 可以通知其他组件…

动态内存管理—C语言通讯录

目录 一&#xff0c;动态内存函数的介绍 1.1 malloc和free 1.2 calloc 1.3 realloc 1.4C/C程序的内存开辟 二&#xff0c;通讯录管理系统 动态内存函数的介绍 malloc free calloc realloc 一&#xff0c;动态内存函数的介绍 1.1 malloc和free void* malloc (…

回文链表(快慢指针解法之在推进过程中反转)

归纳编程学习的感悟&#xff0c; 记录奋斗路上的点滴&#xff0c; 希望能帮到一样刻苦的你&#xff01; 如有不足欢迎指正&#xff01; 共同学习交流&#xff01; &#x1f30e;欢迎各位→点赞 &#x1f44d; 收藏⭐ 留言​&#x1f4dd;抱怨深处黑暗&#xff0c;不如提灯前行…

进程间通信IPC机制

进程间通信&#xff08;IPC&#xff0c;InterProcess Communication&#xff09;是指在不同进程之间传播或交换信息。IPC机制有多种方式&#xff0c;每种方式都有其特定的工作原理、应用场景以及优缺点。以下是对几种主要IPC方式的详细解释&#xff1a; 管道&#xff08;Pipe&a…

数据结构算法题day04

数据结构算法题day04 题目分析算法思想代码完整运行代码如下&#xff1a; 题目 对长度为n的顺序表L&#xff0c;编写一个时间复杂度为O(n)、空间复杂度为O(1)的算法 该算法删除线性表中所有值为X的数据元素。分析 O(n) -> 扫描一次顺序表 O(1) -> 申请常数个辅助空间 1…

代码随想录算法训练营day14|二叉树的递归遍历、二叉树的迭代遍历、二叉树的统一迭代法

二叉树的递归遍历 首先需要明确的一点是&#xff0c;前序中序和后序在二叉树的递归遍历中的区别仅在于递归函数中操作的顺序&#xff0c;前序是在遍历一个节点的左右子树前进行操作&#xff0c;中序是在遍历一个节点的左子树后进行操作再遍历右子树&#xff0c;而后序是在遍历…

C++算术运算和自增自减运算

一 引言 表示运算的符号称为运算符。 算术运算&#xff1b; 比较运算&#xff1b; 逻辑运算&#xff1b; 位运算&#xff1b; 1 算术运算 算术运算包括加、减、乘、除、乘方、指数、对数、三角函数、求余函数&#xff0c;这些都是算术运算。 C中用、-、*、/、%分别表示加、减…

【AI】AI框架项目OpenWebUI如何追加模型

【背景】 openWebUI是一个非常好用的AI框架项目&#xff0c;既可以用API形式连接各类外部AI模型&#xff0c;也可以直接连接服务器硬盘上部署的离线大模型。 简单来说&#xff0c;OpenWebUI可以用来方便地把你的本地模型变为可供所有内网人员使用的SAAS服务站点&#xff0c;并…

《当微服务遇上Ribbon:一场负载均衡的华丽舞会》

在微服务的厨房里&#xff0c;如何确保每一道服务都恰到好处&#xff1f;揭秘Spring Cloud Ribbon如何像大厨一样精心调配资源&#xff0c;让负载均衡变得像烹饪艺术一样简单&#xff01; 文章目录 Spring Cloud Ribbon 详解1. 引言微服务架构中的负载均衡需求Spring Cloud Rib…

【算法实战】每日一题:设计一个算法,用最少数量的矩形覆盖一系列宽度为d、高度为w的矩形,且使用矩形不能超出边界

题目 设计一个算法&#xff0c;用最少数量的矩形覆盖一系列宽度为d、高度为w的矩形建筑物侧墙&#xff0c;且矩形不能超出边界。 核心思路 考虑这种结构 前面递增后面一个与前面的某个高度一致&#xff0c;这时候考虑最下面的覆盖&#xff08;即都是从最下面向上覆盖&#…

redis数据类型set,zset

华子目录 Set结构图相关命令sdiff key1 [key2]sdiffstore destination key1 [key2...]sinter key1 [key2...]sinterstore destination key1 [key2...]sunion key1 [key2...]sunionstore destination key1 [key2...]smove source destination memberspop key [count]sscan key c…

Java GC问题排查的一些个人总结和问题复盘

个人博客 Java GC问题排查的一些个人总结和问题复盘 | iwts’s blog 是否存在GC问题判断指标 有的比较明显&#xff0c;比如发布上线后内存直接就起飞了&#xff0c;这种也是比较好排查的&#xff0c;也是最多的。如果单纯从优化角度&#xff0c;看当前应用是否需要优化&…