算法:关于哈希表中开放寻址法的疑问

发布于 2022-09-12 13:33:14 字数 234 浏览 17 评论 0

image
橙色代表已插入数据的位置,黄色代表未插入数据的位置
将 x 进行哈希计算,得知 x 需插入位置 7,但位置 7 已被占用,故通过线性探测查找到位置 2 未被占用,故插入位置 2

但在查找数据时,将 x 进行哈希计算仍会得到 7,但我之前的数据不是插在 7,而是插在 2,这样找到的不就不是我之前插入的数据了么?没想明白,请教大佬

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

背叛残局 2022-09-19 13:33:14

感觉题主的问题是,没有理解hash算法找数据的详细步骤。
hash过程主要分成两部分:hash值计算方法 和 冲突解决方法

实际使用中,可以把hash存储分成三部分看,key=>value,还有存储地址

如上的问题,通过hash(key)=7,得出的这个7是算出来的第一个存储地址,它里面会保存key。

如果key1,和key2,通过hash算法得出的值是一样的,即hash(key1)=hash(key2)=7,这个就是hash冲突。
根据设置的冲突解决方法来重新找存储地址,比如找到了2,那么2里面保存的实际是(key2=>value2)。

在用key2获取数据时,先执行hash(key2)=7,但是取出7的数据发现是key1。
那么就会按预设的冲突解决算法继续找,找到2发现里面的key2,才会把数据返回,获取到里面的value2

是你 2022-09-19 13:33:14

你所说的问题是存在的,如果要获取x,它是没有办法根据7来获取成功的。

但问题也在这,我们应该没有这样的需要:

// 什么情况下要根据x的值来获取x呢?
x = hasMap.getByValue(x);

所以它有的方法应该类似于这样:

// 判断x是否存在于hasMap中
exists = hasMap.contains(x);

那么此时计算得到的是7。7中没有,则按线性探测的方法继续查找其它的。如果都不等于x,则返回false;如果有一个等于x,则返回true.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文