首页 > 编程知识 正文

hashcat字典,hash表的作用

时间:2023-05-06 05:57:09 阅读:187467 作者:1074

为什么使用dictionary进行查找时,时间复杂度为o(1)?

---》 存储位置=hash(键)

在查找时,首先对键进行hash运算,把求得的值当做“键-值对”的存储位置,在结构中按照此位置取“键-值对”进行比较,若键相等,则表示搜索成功。在存储“键-值对”的时候,依照相同的hash函数计算存储位置,并按此位置存放,这种方法就叫做哈希方法,也叫做散列方法。在哈希方法中使用的转换函数hash被称作哈希函数(或者散列函数)。按照此中算法构造出来的表叫做哈希表(或者散列表)。

哈希函数建立了从“键-值对”到哈希表地址集合的一个映射,有了哈希函数,我们就可以根据键来确定“键-值对”在哈希表中的位置的地址。使用这种方法由于不必进行多次键的比较,查找的时间复杂度为o(1)。

举一个例子,有一组“键值对”:

        <5,”tom”>、<8,”wwdls”>、<12,”Bit”>、<17,”csdse”>、<20,”超帅的枕头”>

我们按照如下哈希函数对键进行计算:

       hash(x)=x%17+3

得出如下结果:

       hash(5)=8、hash(8)=11、hash(12)=15、hash(17)=3、hash(20)=6

我们把<5,”tom”>、<8,”wwdls”>、<12,”Bit”>、<17,”csdse”>、<20,”超帅的枕头”>分别放到地址为8、11、15、3、6的位置上。当要检索17对应的值的时候,只要首先计算17的哈希值为3,然后到地址为3的地方去取数据就可以找到17对应的数据是“csdse”了。

版权声明:该文观点仅代表作者本人。处理文章:请发送邮件至 三1五14八八95#扣扣.com 举报,一经查实,本站将立刻删除。