经过一上午的学习,对数据结构有了新的认识和理解

数组

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

索引结果和散列技术_索引结果和散列技术

链表

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

索引结果和散列技术_链表_02

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

索引结果和散列技术_链表_03

队列

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

索引结果和散列技术_javascript_04

散列表(哈希表)

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

索引结果和散列技术_数据结构_05


1.什么是开发地址法?

当冲突发生时,通过查找数组的一个空位,并将数据填入,而不再用哈希函数得到的数组下标,这个方法叫做开放地址法。

2.什么是链地址法:
在哈希表每个单元中设置链表,某个数据项的关键字还是像通常一样映射到哈希表的单元中,而数据项本身插入到单元的链表中。