千锋教育-做有情怀、有良心、有品质的职业教育机构

400-811-9990
手机站
千锋教育

千锋学习站 | 随时随地免费学

千锋教育

扫一扫进入千锋手机站

领取全套视频
千锋教育

关注千锋学习站小程序
随时随地免费学习课程

上海
  • 北京
  • 郑州
  • 武汉
  • 成都
  • 西安
  • 沈阳
  • 广州
  • 南京
  • 深圳
  • 大连
  • 青岛
  • 杭州
  • 重庆
当前位置:郑州千锋IT培训  >  技术干货  >  哈希表是什么?

哈希表是什么?

来源:千锋教育
发布人:xqq
时间: 2023-10-14 12:49:16

一、哈希表是什么

哈希表(Hash table)又叫散列表,是一种可以根据键值(Key value)直接访问的数据结构。哈希表会通过某种哈希算法计算一个键值的函数(这个函数也叫哈希函数或散列函数),并将所查询的数据映射到某个位置以供访问,借此加快查找特定键值的速度。

哈希表的工作原理可以用这样一个直观的例子来说明:

字典中收录了大量汉字的信息。为了便于快速找到某个字,可以首先创建一个按照每个字的拼音字母顺序排列的表(也就是字典开头部分的“拼音检字表”),这就类似于在每个字和拼音字母之间建立了一种函数关系。要查找某个字时,只需在这个表中依次定位首字母、第二个字母、第三个字母…… 以此类推,大部分时候甚至不需要完整查找该字拼音的每个字母,就能确定这个字在字典中对应的准确位置。

在上述例子中,“查找拼音的第n的字母”就是哈希函数的函数法则,而“拼音检字表”就可以理解为一种哈希表(或散列表)。

延伸阅读:

二、什么是哈希值(hash code)

哈希值是一个int类型的整数。每个元素都应该有自己的哈希值,并且这个值是少数的。即满足:

A.如果元素a与元素b相等,则元素a的哈希值与元素b的哈希值相等。

B.如果元素a与元素b不相等,则元素a的哈希值与元素b的哈希值不相等。

通常情况下,对于int,bool,double,string等语言自带的类型都有自己的哈希值,可以用它们的哈希函数来获取,不同语言的哈希函数可能会不同。

如果是用户自己新建的类型,则需要提供计算此类型元素哈希值的哈希函数。

在哈希表中,我们是通过某元素的哈希值来查找、添加或删除元素的。

 

声明:本站稿件版权均属千锋教育所有,未经许可不得擅自转载。

猜你喜欢LIKE

完全二叉树为什么非常适合顺序存储结构?

2023-10-14

数据结构里面pnext与next有什么区别?

2023-10-14

什么叫精益管理?

2023-10-14

最新文章NEW

Java中遍历数据结构Enumeration和Iterator相比有什么不同?

2023-10-14

数组与集合有什么不同?

2023-10-14

ASPICE是什么?

2023-10-14

相关推荐HOT

更多>>

快速通道 更多>>

最新开班信息 更多>>

网友热搜 更多>>