数组,链表,栈,队列,散列表

1,157 阅读1分钟

重温了数据结构 ,温故而知新。

数组

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

链表

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

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

队列

队列是也是一种线性逻辑结构,可以用数组实现,也可以使用链表实现。队列包含入队和出兑的事件,遵循先入先出的原则(FIFO)

散列表(哈希表)

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

备注:哈希函数 最简单的方式是取模运算,实际上JDK利用了位运算的方式俩优化性能

index = HashCode(Key) % Array.length

参考《漫画算法》