标签:遍历数组 lazy 通过 ble 出队 产生 时空 优先级 alt
分类:
时间和空间复杂度:
数组是可以再内存中连续存储多个元素的结构,在内存中的分配也是连续的,数组中的元素通过数组下标进行访问,数组下标从0开始。
适用场景:
优点:
缺点:
时间复杂度 | O() |
---|---|
Access | O(1) |
Insert | O(n) |
Delete | O(n) |
链表是物理存储单元上非连续的、非顺序的存储结构;
数据元素的逻辑顺序是通过链表的指针地址实现,每个元素(结点)包含两个域,一个是存储元素的数据域 (内存空间),另一个是指向下一个结点地址的指针域。
根据指针的指向,链表能形成不同的结构,例如单链表,双向链表,循环链表等。
链表插入Node:
链表删除Node:
时间复杂度 | O() |
---|---|
space | O(1) |
prepend | O(1) |
append | O(1) |
lookup | O(n) |
insert | O(1) |
delete | O(1) |
栈是一种特殊的线性表;仅能在线性表的一端操作,栈顶允许操作,栈底不允许操作。
栈的特点:
队列与栈一样,也是一种线性表;队列可以在一端添加元素,在另一端取出元素,也就是“先进先出”;从一端放入元素的操作称为入队,取出元素为出队 ;
使用情景:
双端队列和普通队列区别在于:队头和队尾都可以插入和删除元素;
优先队列:正常?、按照优先级出
树是一种数据结构,它是由n(n>=1)个有限节点组成一个具有层次关系的集合。把它叫做 “树” 是因为它看起来像一棵倒挂的树,也就是说它是根朝上,而叶朝下的。
树的特点:
二叉树:
二叉搜索树:
堆是一种比较特殊的数据结构,可以被看做一棵树的数组对象,具有以下的性质:
小顶堆特点:
大顶堆特点:
图是由结点的有穷集合V和边的集合E组成。其中,为了与树形结构加以区别,在图结构中常常将结点称为顶点,边是顶点的有序偶对;若两个顶点之间存在一条边,就表示这两个顶点具有相邻关系。
哈希表,是根据关键码和值 (key和value) 直接进行访问的数据结构,哈希底层算法是取模(取余)运算,所以会产生哈希冲突。
哈希冲突解决:拉链法
标签:遍历数组 lazy 通过 ble 出队 产生 时空 优先级 alt
原文地址:https://www.cnblogs.com/pankypan/p/13244790.html