【发布时间】:2016-01-12 00:48:24
【问题描述】:
我的意思是,我已经使用这个表达式实现了一个通用散列函数:
h(k) = ((a*k + b)mod p)mod m; (来自科门)
在哪里: -p 是大于 k 的大素数; -a 和 b 是随机选择的两个数字,第一个在 [1, p-1] 范围内,第二个在 [0, p-1] 范围内随机选择。
现在,我实现了这个,对于随机函数,我选择了等于 k 的种子。那是因为,如果我不这样做,当我用键 k 插入一个值时,它会生成一个哈希值,这将取决于 Random 函数的默认种子(可能是时间)。所以如果我想再次搜索密钥,我不能这样做,因为现在通用散列函数返回了另一个值。所以,我很感激你告诉我我的推理是否正确。 我的疑问是,现在这样做,如果两个元素具有相同的键,它们将被无条件地存储在同一个链表中(我不明白它是否正确)。
提前致谢。
【问题讨论】: