漫画算法:小灰的算法之旅

《漫画算法小灰的算法之旅》介绍了数据结构基础,包括数组、链表、栈、队列和散列表的概念。数组具有随机访问优势,但插入删除效率低;链表则反之。栈和队列遵循特定出栈和出队原则,可用于递归、面包屑导航等场景。散列表通过哈希函数快速存取,解决冲突有开放寻址法和链表法。
摘要由CSDN通过智能技术生成

本书:<<漫画算法小灰的算法之旅>>
作者:魏梦舒(@程序员小灰)
我是将本书中内容,重新整理一遍。基本是书中的内容,方便以后阅读查看!!!希望喜欢本书的小伙伴们可以相互学习,多多支持!

第二章数据结构基础

  • 什么是数组?
  • 什么是链表?
  • 什么是栈?
  • 什么是队列?
  • 什么是散列表?

1、数组是由有限个相同类型的变量所组成的有序集合,它的物理存储方式是顺序存储,访问方式是随机访问。利用下标查找数组元素的时间复杂度是O(1),中间插入、删除数组元素的时间复杂度是O(n)。
2、链表是一种链式数据结构,由若干节点组成,每个节点包含指向下一节点的指针。链表的物理存储方式是随机存储,访问方式是顺序访问。查找链表节点的时间复杂度是O(n),中间插入、删除节点的时间复杂度是O(1)。
3、栈是一种线性逻辑结构,可以用数组实现,也可以用链表实现。栈包括入栈和出栈操作,遵循先入后出的原则(FILO)。
4、队列也是一种线性逻辑结构,可以用数组实现,也可以用链表实现。队列包含入队和出队操作,遵循先入先出的原则(FIFO)。
5、散列表也叫哈希表,是存储Key-Value映射的集合。对于某一个Key,散列表可以在接近O(1)的时间内进行读写操作。散列表通过哈希函数实现Key和数组下标的转换,通过开放寻址法和链表法来解决哈希冲突。
2.1.1初始数组

  • 数组的
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值