前五天是之前学过的一些基础内容,过的比较快,留一张图总结一下,接触到一个之前一直没遇到过的字典的底层原理: 存入时,需要先计算key值的散列值a,假设要存入的数组长度为8(化成二进制1000).然后对a后三为进行取值,即取出的值为0~7对应的二进制数据,假设取到6对应的二进制数,先判断6位置有没有数据,没有则存入序号6对应的位置,有则再向后三位取值,重复上面找位置的操作.如果数组填满了,则会自动扩容.
学习笔记(1~5)Day.
最新推荐文章于 2024-10-08 12:37:10 发布
这篇博客回顾了前五天的学习内容,重点介绍了字典的底层实现。在存入字典时,通过计算key的散列值并根据数组长度进行定位。如果位置已被占用,则继续寻找下一个可用位置,直至找到或触发自动扩容。这个过程涉及到关键的散列算法和数组扩容机制。
摘要由CSDN通过智能技术生成