欧意交易所资讯

uncategorized
首页 > 欧意交易所资讯 > 正文内容

哈希表(Hash Table)

2年前 (2024-07-05)欧意交易所资讯

哈希表(Hash Table)

概览:

​ 简单来说,哈希表是一种依赖哈希函数组织数据,以达到常数级别时间复杂度,插入和搜索都非常高效的数据结构。

两种哈系表:

哈希集合是集合数据结构的实现之一,用于存储非重复值。哈希映射是映射 数据结构的实现之一,用于存储(key, value)键值对。

大多数高级程序设计语言标准库里都内置了哈系表模板。

1、哈希表的原理

哈希表的关键思想是使用哈希函数将键映射到存储桶。更确切地说,

当我们插入一个新的键时,哈希函数将决定该键应该分配到哪个桶中,并将该键存储在相应的桶中;当我们想要搜索一个键时,哈希表将使用相同的哈希函数来查找对应的桶,并只在特定的桶中进行搜索。

示例

在示例中,我们使用 y = x % 5 作为哈希函数。让我们使用这个例子来完成插入和搜索策略:

插入:我们通过哈希函数解析键,将它们映射到相应的桶中。例如,1987 分配给桶 2,而 24 分配给桶 4。搜索:我们通过相同的哈希函数解析键,并仅在特定存储桶中搜索。如果我们搜索 1987,我们将使用相同的哈希函数将1987 映射到 2。因此我们在桶 2 中搜索,我们在那个桶中成功找到了 1987。例如,如果我们搜索 23,将映射 23 到 3,并在桶 3 中搜索。我们发现 23 不在桶 3 中,这意味着 23 不在哈希表中。

哈希散列函数:

​ 可以看得出元素存储位置与它的关键字建立了一个对应关系F,在查找时就可以由键通过哈希函数映射出元素的索引位置(桶),而对应关系F就是哈希散列函数。哈希函数是哈希表中最重要的组件,哈希表用于将键映射到特定的桶。上述示例中y = x % 5 作为散列函数,其中 x 是键值,y 是分配的桶的索引。

​ 散列函数将取决于键值的范围和桶的数量。

下面是一些哈希函数的示例:

​ 哈希函数的设计是一个开放的问题。其思想是尽可能将键分配到桶中,理想情况下,完美的哈希函数将是键和桶之间的一对一映射。然而,在大多数情况下,哈希函数并不完美,它需要在桶的数量和桶的容量之间进行权衡。

2、冲突解决

理想情况下,如果我们的哈希函数是完美的一对一映射,我们将不需要处理冲突。不幸的是,在大多数情况下,冲突几乎是不可避免的。例如,在我们之前的哈希函数(y = x % 5)中,1987 和 2 都分配给了桶 2,这是一个冲突(所以映射位置称之为桶,因为冲突时还需要在桶内作二次查找找到元素的位置)。

​ 可以简单地使用一个数组将键存储在同一个桶中。如果 N 是可变的或很大,我们可能需要使用高度平衡的二叉树来代替。

3、复杂度分析

如果总共有 M 个键,那么在使用哈希表时,可以达到 O(M) 的空间复杂度。

而哈希表的时间复杂度与设计有很强的关系。

以使用数组来将值存储在同一个桶中为例,理想情况下,桶的大小足够小时,可以看作是一个常数。插入和搜索的时间复杂度都是 O(1)。

但在最坏的情况下,桶大小的最大值将为 N。插入时时间复杂度为 O(1),搜索时为 O(N)。

内置哈希表的原理

高级程序设计语言内置哈希表的典型设计是:

键值可以是任何可哈希化的类型。并且属于可哈希类型的值将具有哈希码。此哈希码将用于映射函数以获取存储区索引。每个桶包含一个数组,用于在初始时将所有值存储在同一个桶中。如果在同一个桶中有太多的值,这些值将被保留在一个高度平衡的二叉树搜索树中。

插入和搜索的平均时间复杂度仍为 O(1)。最坏情况下插入和搜索的时间复杂度是 O(logN),使用高度平衡的 BST。这是在插入和搜索之间的一种权衡。

欢迎关注微.信公.众号:爱写Bug

扫描二维码推送至手机访问。

版权声明:本文由欧意交易所app官方下载发布,如需转载请注明出处。

转载请注明出处https://doumiduoduo.cn/post/1294.html

相关文章

中国跨境电商交易会(春季)开幕,潮州 17 家企业集中亮相展示潮品出海势能

中国跨境电商交易会(春季)开幕,潮州 17 家企业集中亮相展示潮品出海势能

据悉,本次潮州电商团集结了陶瓷、不锈钢、服装、小家电、节庆礼品、食品等企业,还增加了跨境电商服务企业参展,以“中国(潮州)跨境电子商务综合试验区”为统一标识,形成集中展区,展示众多企业优质新品,打造...

曾靠6字赚苹果上千万的汉王,怎么就搭上ChatGPT的风口回顾“一尿成名”任素汐:上半身平凡,下半身贪婪,丑和性感相结合

曾靠6字赚苹果上千万的汉王,怎么就搭上ChatGPT的风口回顾“一尿成名”任素汐:上半身平凡,下半身贪婪,丑和性感相结合

人工智能已经不是只出现在科幻小说和电影里出现的存在了。 紧随区块链、元宇宙的概念,OpenAI 训练下的语言模型 ChatGPT-3.5 的问世令人兴奋。当Siri、Alexa、小度...

工商银行申请会话密钥的生成方法、装置、处理器及电子设备专利,解决了生成会话密钥时,会话密钥容易被破解的技术问题新版“黄蓉”一亮相,粉碎了多少人心中的武侠梦!

金融界2023年12月7日消息,据国家知识产权局公告,中国工商银行股份有限公司申请一项名为“会话密钥的生成方法、装置、处理器及电子设备“,公开号CN117176329A,申请日期为2023年...

币圈十大交易所 app 详细介绍,安全可靠功能强大,你值得拥有

币圈十大交易所 app 详细介绍,安全可靠功能强大,你值得拥有

安币() 安比是全球最大的加密货币交易所之一。其应用程序支持和iOS系统。安比拥有广泛的交易对、低廉的交易费用和一流的技术支持。币币还提供了丰富的功能,如杠杆交易、期货交易、币币宝等,满足不同投资者的...

非法控制100多万台电脑,“挖矿”两年,获利1500万

非法控制100多万台电脑,“挖矿”两年,获利1500万

控制100多万台电脑,“挖矿”两年,获利1500万通过计算机运算获取数字货币,俗称“挖矿”。犯罪团伙非法控制100多万台电脑“挖矿”,得到数字货币后兑换成人民币,9名嫌疑人...

以太坊 ETF 获批后,DOGE、ADA和 SOL将迎来爆炸式增长

以太坊 ETF 获批后,DOGE、ADA和 SOL将迎来爆炸式增长

目前,加密货币市场的市值为 1.42 万亿美元,正在经历一个以山寨币暴跌为标志的独特阶段。尽管如此,人们还是对潜在的飙升抱有期待,尤其是在以太坊 ETF 获得批准之后。这种环境为狗...

欧意交易平台 v67.72.1 2024 官方安卓版

欧意交易所app是一款专业的比特币交易平台,还支持莱特币、以太币等数字货币,提供及时丰富的行业资讯,支持多种币种在线交易,专业分析师在线直播提供精准的指导意见,帮助用户把握投资时机,全球排名第一的虚拟货币交易所已全新升级,提供多种加密货币在线交易,种类丰富,在线交易流程简单,金融级加密技术,使用起来绝对安全!目标是向区块链技术爱好者提供更多的区块链比特币相关的资讯及优质内容。