野生前端的数据结构基础练习(5)——散列(前端,基础练习,结构基础,web开发)

时间:2024-05-05 15:48:37 作者 : 石家庄SEO 分类 : web开发
  • TAG :

野生前端的数据结构基础练习(5)——散列

网上的相关教程非常多,基础知识自行搜索即可。

习题主要选自Orelly出版的《数据结构与算法javascript描述》一书。

参考代码可见:https://github.com/dashnowords/blogs/tree/master/Structure/Hash

散列的基本知识

  • 常见散列函数

    使用×××键对存储空间长度取模,所以存储空间长度一般取质数(取质数可以减小散列碰撞,不难理解)。

  • 散列碰撞的一般解决方法

    位置发生碰撞时使用链表或其他数据结构将碰撞元素连接起来。

    当发生哈希碰撞时,从当前位置向后寻找到第一个没有使用的位置,将要加入的数据放在该处。一般在可使用空间大于待存数据量2倍时使用。

  • 散列函数应用

    散列函数相关的应用非常广,例如webpack打包时在文件名中添加的哈希值,将给定信息转换为固定位数字符串的加密信息等都是散列的实际应用,感兴趣的读者可以自行搜索加密摘要算法相关关键词进行学习。

    基本练习

    编写一个简易Hash类:

  • 方法
  • 课后习题(书中第八节习题)

    习题思路

    练习时可以先引入例题中的Hash类,然后通过extends来继承Hash类并复写set/get方法或添加新的方法。

     </div> <div class="zixun-tj-product adv-bottom"></div> </div> </div> <div class="prve-next-news">
    本文:野生前端的数据结构基础练习(5)——散列的详细内容,希望对您有所帮助,信息来源于网络。
    上一篇:webpack4.x最详细入门指南下一篇:

    18 人围观 / 0 条评论 ↓快速评论↓

    (必须)

    (必须,保密)

    阿狸1 阿狸2 阿狸3 阿狸4 阿狸5 阿狸6 阿狸7 阿狸8 阿狸9 阿狸10 阿狸11 阿狸12 阿狸13 阿狸14 阿狸15 阿狸16 阿狸17 阿狸18