数据结构笔记(4)散列

定义

散列是一种用于以常数平均时间执行插入、删除和查找的技术。但是并不支持元素间需要排序信息的操作,比如FindMin()、FindMax()等。


散列表数据结构

理想的散列表数据结构不过是一个包含有关键字的具有固定大小的数组。

每个关键字被映射到0~TableSize-1中的某个数,这个映射被称为散列函数(hash function)。理想状况下的散列函数应该运算简单且保证任何两个不同的关键字映射到不同的单元,但是对于有限长度的散列表,不可能容纳无限的关键字,所以我们要寻找一个合适的散列函数将关键字均匀的映射到不同的单元。

当两个关键字散列到同一个单元时,我们称之为发生冲突(collision)。


散列函数

  • 通常保证表的大小为素数。
  • emmm,找到一个好的散列函数——足够大,足够快,平均分布。
  • 当冲突发生时,我们通过两种方法来解决冲突:
    • 分离链接法
    • 开放定址法
  • 以后补充。

分离链接法

做法:将散列到同一个值的所有元素保留到一个表中。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值