哈希地址

三楚雄风 2015-07-16 12:54:29
对于哈希地址还是不大了解啊。哈希地址是实际的物理地址吗?看到一个博客,哈希表是基于数组的,是不是说哈希地址是物理上连续的一块内存区域?


然后,不同的冲突处理方法。线性探测再散列:Hi=(H(key) + di) MOD m。用这种方法,最后放到哈希表的元素不会超过哈希表的长度。
但是要是用链地址法,每一个哈希地址对应一个链表,可以放很多元素。这样一个哈希表放的元素就可以多于哈希地址的数量了。那么这里的哈希地址就不是元素实际的物理地址了。

所以我想问的是:1.哈希地址是不是实际物理地址
2.有1000个哈希地址,是不是哈希表放的元素不能超过1000(如果链地址法多于1000呢?)
...全文
584 4 打赏 收藏 转发到动态 举报
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
tyrone_li 2015-07-17
  • 打赏
  • 举报
回复
理论上肯定可以超过1000,但是链地址法和线性探测一般都会设定一个加载因子,元素个数超过临界值就会进行扩容。否则就会导致很多次碰撞,效率降低的
shiyi_xie 2015-07-16
  • 打赏
  • 举报
回复
哈希地址肯定不是实际物理地址。hash只是一个计算值,甚至有可能会一样。 看源码。。。。
alan19931103 2015-07-16
  • 打赏
  • 举报
回复
1,理论上是,但是具体实现上可以不是。 2,是的
BS0jiedi 2015-07-16
  • 打赏
  • 举报
回复
不太清楚,坐等高人
 本次课程会带着大家学习Hash算法,从源码的角度去学习算法,更加容易理解的方式去学习,能够更高效的吸收学到的内容,也能培养出能够独自看源码,分析源码的能力。Hash,一般翻译做“散列”,也有直接音译为“哈希”的,就是把任意长度的输入(又叫做预映射, pre-image),通过散列算法,变换成固定长度的输出,该输出就是散列值。这种转换是一种压缩映射,也就是,散列值的空间通常远小于输入的空间,不同的输入可能会散列成相同的输出,而不可能从散列值来唯一的确定输入值。简单的说就是一种将任意长度的消息压缩到某一固定长度的消息摘要的函数。  哈希表是根据设定的哈希函数H(key)和处理冲突方法将一组关键字映射到一个有限的地址区间上,并以关键字在地址区间中的象作为记录在表中的存储位置,这种表称为哈希表或散列,所得存储位置称为哈希地址或散列地址。作为线性数据结构与表格和队列等相比,哈希表无疑是查找速度比较快的一种。  通过将单向数学函数(有时称为“哈希算法”)应用到任意数量的数据所得到的固定大小的结果。如果输入数据中有变化,则哈希也会发生变化。哈希可用于许多操作,包括身份验证和数字签名。也称为“消息摘要”。  简单解释:哈希(Hash)算法,即散列函数。它是一种单向密码体制,即它是一个从明文到密文的不可逆的映射,只有加密过程,没有解密过程。同时,哈希函数可以将任意长度的输入经过变化以后得到固定长度的输出。哈希函数的这种单向特征和输出数据长度固定的特征使得它可以生成消息或者数据。

62,614

社区成员

发帖
与我相关
我的任务
社区描述
Java 2 Standard Edition
社区管理员
  • Java SE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧