链表和二叉树基础

链表

什么是链表?

	链表[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
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值