漫画算法:小灰的算法之旅笔记(1)

作者: dino.ma 分类: PHP 发布时间: 2019-10-12 17:40

什么是数组?

数组是又有限个相同类型的变量所组成的有序集合,它的物理存储方式是顺序存储,访问方式是随机访问。利用下标查找数组元素的时间复杂度是O(1),中间插入、删除数组元素的时间负责度是O(n)。

什么是链表?

链表是一种链式数据结构,由若干节点组成,每个节点包含指向下一节点的指针。链表的物理存储方式是随机存储。访问方式是顺序访问。查找链表节点的时间复杂度是O(n),中间插入、删除节点的时间复杂度是O(1)。

什么是栈

栈是一种线性逻辑结构,可以用数组、链表做实现。栈包含入栈和出栈操作,遵循先入后出的原则(FILO)。

什么是队列

队列也是一种线性逻辑结构,可以用数组、链表实现。队列包含入队和出队操作,祖训先入先出原则(FIFO)。

什么是散列表

散列表也叫哈希表,是存储Key-Value映射的集合。对于某一个Key,散列表可以在接近O(1)的时间内进行读写操作。散列表通过哈希函数实现Key和数组下标的转换,通过开放寻址法和链表法来解决哈希冲突。

github地址:https://github.com/dino-ma/algorithm

发表评论

电子邮件地址不会被公开。 必填项已用*标注