链表
什么是链表?
链表[Linked List]:链表是由一组不必相连(可以连续也可不连续)的内存结构(节点),按特定的顺序连接在一起的抽象数据类型。
补充:
抽象数据类型(Abstract Data Type [ADT]):表示数学中抽象出来的一些操作集合。
内存结构:内存结构中的,如: struct 、特殊内存块...等等之类;
数组和链表的区别优缺点:
数组是一种连续存储线性结构,元素类型相同大小等
数组的优点:
存取速度快
数组的缺点:
事先必须知道数组的长度
插入删除元素很慢
空间通常是有限制的
需要大块连续的内存
插入删除元素的效率很低
链表是离散存储线性结构
n个节点离散分配,彼此通过指针相连,每个节点只有一个前驱节点,每个节点只有一个后续节点,首节点没有前驱节点,尾节点没有后续节点。
链表优点:
空间没有限制
插入删除元素很快
链表缺点:
存取速度很慢
链表分类
链表常用的有3类:单链表、双向链表、循环链表。
链表的核心操作有3种:插入、删除、查找(遍历)
单链表
单链表[Linked List]:由各个内存结构通过一个Next指针链接在一起组成,每一个内存结构都存在后续内存结构(链尾除外),内存结构由数据域和Next指针域组成。
单链表实现图示:
解析:
Data 数据 + Next 指针,组成一个单链表的内存结构;
第一个内存结构称为链头,最后一个内存结构称为链尾;
链尾的Next 指针设置为NULL[指向空];
单链表的遍历方向单一(只能从链头一直遍历到链尾)
单链表操作集
二叉树
什么是二叉树?
二叉树是树的一种,每个节点最多可具有两个子树,即节点的度(节点拥有的子树集)最大为2。
树的一些概念:
二叉树就是每个节点不能多于两个儿子,如上图,而且这是一个特殊的二叉树:二叉查找树(binary search tree)。
- 定义:当根节点的左边全部比根节点小,当前根节点的右边全部比根节点大。
- 可以看出,这对我们来找一个数是非常方便快捷的。
一棵树至少有一个节点(根节点)
树由节点组成,每个节点的数据结构是这样的:
因此,我们定义树的时候往往是先定义节点 ,节点连接起来就成了树,而节点的定义就是:一个数据、两个指针(如果有节点就指向节点、没有节点就指向null)
二叉树种类
斜树
所有节点都只有左子树或右子树。
满二叉树
所有的分支节点都具有左右节点
完全二叉树
若设二叉树的深度为 h,除第 h 层外,其它各层 (1~h-1) 的结点数都达到最大个数,第 h
层所有的结点都连续集中在最左边,这就是完全二叉树。
二叉树的一些性质
二叉树第 i 层上的结点数目最多为 2^(i-1) (i≥1)
深度为 h 的二叉树至多有 2^h-1 个结点(h≥1)
包含 n 个结点的二叉树的高度至少为 log2(n+1)
在任意一棵二叉树中,若终端结点的个数为 n0,度为 2 的结点数为 n2,则 n0 = n2 + 1
二叉树的遍历方式
二叉树的遍历方式,一般分为先序遍历,中序遍历,后序遍历。
- 先序遍历
- 先访问根节点,然后访问左节点,最后访问右节点(根->左->右)
- 中序遍历
- 先访问左节点,然后访问根节点,最后访问右节点(左->根->右)
- 后序遍历
- 先访问左节点,然后访问右节点,最后访问根节点(左->右->根)
先序遍历(根-左-右):1-2-4-8-9-5-10-3-6-7
中序遍历:(左-根-右):8-4-9-2-10-5-1-6-3-7
后序遍历(左-右-根):8-9-4-10-5-2-6-7-3-1
- 先访问左节点,然后访问右节点,最后访问根节点(左->右->根)