数据结构与算法——复习总结

news2025/1/22 15:01:11

线性表

线性表括顺序表和链式表。

栈(Stack)是只允许在一端进行插入或删除操作的线性表。应用:表达式求值,函数递归调用

队列(Queue)是只允许在一端进行插入,在另一端删除的线性表。应用:树和图的广度优先遍历,操作系统FCFS算法

双端队列:只允许从两端插入、两端删除的线性表

前缀、后缀、中缀表达式

在这里插入图片描述
在这里插入图片描述

KMP算法

假设匹配字符串为s,模板字符串为t,算法核心是计算出一个next数组,next[j]的含义是当模板字符串的t[j]不匹配时,往后挪移到next[j]下标的位置。

树是由零个或多个结点组成的具有层级关系的数据结构。

树是n(n≥0)个结点的有限集合,n = 0时,称为空树,这是一种特殊情况。在任意一棵非空树中应满足:
1)有且仅有一个特定的称为根的结点。
2)当n > 1时,其余结点可分为m(m > 0)个互不相交的有限集合T1, T2,…, Tm,其中每个集合本身又是一棵树,并且称为根结点的子树。

属性:

  • 结点的层次(深度)―—从上往下数
  • 结点的高度――从下往上数
  • 树的高度(深度)――总共多少层
  • 结点的――有几个孩子(分支),树的结点数 = 各结点度数之和 + 1
  • 树的度――各结点的度的最大值

有序树——逻辑上看,树中结点的各子树从左至右是有次序的,不能互换。反之就是无序树

森林。森林是m(m≥0)棵互不相交的树的集合

二叉树

二叉树是有序树

特殊二叉树:

  • 满二叉树,每层都是满的
  • 完全二叉树,除了最后一层可以不满
  • 二叉排序树(二叉查找树、二叉搜索树):对于每个结点,左子树所有结点值 < 父节点值 < 右子树所有节点值,不允许结点之间有重复值。
  • 平衡二叉树。树上任一结点的左子树和右子树的深度之差不超过1

二叉树遍历:先序Preorder——根、左、右;中序Inorder——左、根、右;后序Postorder——左、右、根;bfs层序遍历

线索二叉树是对二叉树进行线索化,使某些二叉树节点可以直接访问到左右子节点以外的节点。
对于二叉树进行先序遍历得到一个先序序列,先序线索化结点的左孩子指向序列中的前驱节点,右孩子指向后继节点。
同样的,依据中序序列、后序序列可以得到中序、后序的线索二叉树。
在这里插入图片描述

树和二叉树之间的转换,左孩子右兄弟
在这里插入图片描述
森林和二叉树的转换依然是左孩子右兄弟,森林中各个树的根结点视为兄弟关系
在这里插入图片描述

二叉排序树

二叉排序树的插入:若原二叉排序树为空,则直接插入结点;否则,若关键字k小于根结点值,则递归插入到左子树(如果左子树为空则直接挂在左孩子结点上),若关键字k大于根结点值,则递归插入到右子树(同上)。

对于二叉排序树来说,它的中序遍历序列是一个递增序列。

二叉排序树的删除:
① 若被删除结点z是叶结点,则直接删除,不会破坏二叉排序树的性质。
② 若结点z只有一棵左子树或右子树,则让z的子树成为z父结点的子树,替代z的位置。
③ 若结点z有左、右两棵子树,我们删除左子树中值最大的结点或者右子树中值最小的结点,然后用该节点替换结点z即可。
在这里要解释一下,由于中序遍历是递增的,所以左子树值最大的结点就是中序序列中z结点的前驱节点,右子树中值最小的结点就是z节点的后继节点。
对于左子树值最大的节点,因为它的值在子树中是最大的,所以必然不含右孩子,所以肯定符合情况①或情况②,很容易删除;对于右子树中值最小的结点也是同样的道理。
其实还有一种寻找左子树中值最大的结点的方法,从左子节点开始,递归搜索它的右孩子,右孩子为空时,该节点就是左子树中值最大的结点。
在这里插入图片描述

平衡二叉树

平衡二叉树,也就是每个结点的左右子树高度不超过1,关键问题在于插入新结点时如何维护二叉树的平衡性。
在插入结点时,每次调整的对象都是“最小不平衡子树”
结点的平衡因子=左子树高-右子树高。

在这里插入图片描述
LL和RR很像,是对称的关系
在这里插入图片描述
在这里插入图片描述

LR和RL待补充。。。。

哈夫曼树

结点的权:有某种现实含义的数值(如:表示结点的重要性等)
结点的带权路径长度:从树的根到该结点的路径长度(经过的边数)与该结点上权值的乘积
树的带权路径长度:树中所有叶结点的带权路径长度之和(WPL,Weighted Path Length)

在含有n个带权叶结点的二叉树中,其中**带权路径长度(WPL)**最小的二叉树称为哈夫曼树,也称最优二叉树

在这里插入图片描述
在这里插入图片描述

对于无向图:顶点v的度是指依附于该顶点的边的条数,记为TD(v)。

对于有向图:
入度是以顶点v为终点的有向边的数目,记为ID(v);
出度是以顶点v为起点的有向边的数目,记为OD(v)。
顶点v的度等于其入度和出度之和,即TD(v) = ID(v) + OD(v)。

在这里插入图片描述
连通的概念存在于无向图中,强连通的概念存在于有向图中

若图G中任意两个顶点都是连通的,则称图G为连通图,否则称为非连通图。
若图中任何一对顶点都是强连通的,则称此图为强连通图。

无向图中的极大连通子图称为连通分量。
有向图中的极大强连通子图称为有向图的强连通分量。

连通图的生成树是包含图中全部顶点的一个极小连通子图。
在非连通图中,连通分量的生成树构成了非连通图的生成森林。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

无向完全图——无向图中任意两个顶点之间都存在边
有向完全图——有向图中任意两个顶点都存在都存在方向相反的两条弧

特殊的图:
树——不存在回路,且连通的无向图
有向树——一个顶点的入度为0、其余顶点的入度均为1的有向图,称为有向树。

在这里插入图片描述

邻接矩阵存图,空间复杂度O(V ^ 2), V是顶点数
邻接表存图,空间复杂度O(V + E),E是边数

十字链表存有向图、邻接多重表存无向图待补充。。。

图的遍历

BFS广度优先遍历对应广度优先生成树
在这里插入图片描述
在这里插入图片描述
BFS,对应深度优先生成树
在这里插入图片描述

最小生成树

很简单,不说了。
在这里插入图片描述

最短路

bfs可以求无权最短路。

dijkstra求单源最短路,要求边权为非负数,复杂度O(V ^ 2)
floyd求多源最短路,边权可以为负数

拓扑排序,逆拓扑排序

EOV图的关键路径,求关键路径步骤如下:

  • 起始事件的最早开始时间是0,顺着箭头的方向正向推导,求得各个事件的最早开始时间。代码上体现为BFS。
  • 在上个步骤中已求得结束事件的最早开始时间,结束事件的最晚开始时间等于最早开始时间,然后逆着箭头的方向倒着推导,求出各个时间的最晚开始时间。代码上体现为BFS。
  • 最早开始时间等于最晚开始时间的事件组成的路径,就是关键路径。

活动的最早开始事件等于前驱事件的最早开始事件,活动的最晚开始时间等于后继事件的最晚开始时间 - 活动持续时间

在这里插入图片描述

查找

折半查找时间复杂度= O(log2n)
顺序查找的时间复杂度= O(n)
在这里插入图片描述

B树

B树是二叉排序树的plus版,一个结点内可以多个值,一个结点可以有多个子结点。结点内的值是有序的,多个子结点的值之间也是有序的。
m阶B树每个结点至多含有m-1个关键字
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

B树的插入与删除

这篇文章写的比较好

B树的插入操作,一定是插入到树的叶子结点里,从树根开始递归搜索,找到应该插入的那个叶子结点然后插入即可。
如果插入后叶子结点的值个数等于树的阶,那么需要把这个结点以中间值为界限分裂成两个结点,把中间值送给父节点。如果父节点的值的个数也等于树的阶,那么对父节点递归进行分裂操作。

B+树

在B树中,叶子结点和非叶子结点都可以存放值,然而B+树的非叶子节点是不保存数据的,只起到索引作用,它的叶子节点才保存数据

B+ 树 的数据结构中,叶子节点之间形成了单向链表。每一个节点的指针,通过叶子节点指向下一个元素。

典型应⽤:关系型数据库的“索引”(如MySQL)
在B+树中,⾮叶结点不含有该关键字对应记录的存储地址。 可以使⼀个磁盘块可以包含更多个关键字,使得B+树的阶更⼤,树⾼更矮,读磁盘次数更少,查找更快

在这里插入图片描述
在这里插入图片描述

红黑树

散列查找 hash查找

散列表(Hash Table),⼜称哈希表。是⼀种数据结构,特点是:数据元素的关键字与其存储地址直接相关

把key值映射到hash表的过程称为散列函数,常⻅的散列函数:除留余数法 —— H(key) = key % p

当有两个key映射到相同的hash值时,我们称之为哈希冲突,可以使用“拉链法”解决这种冲突,也就是邻接表,如下图所示,
在这里插入图片描述

也可以用开放定址法解决冲突,当插入元素存在hash冲突时把它存放在邻近的空位置里,如下图中的1、68、27,他们的hash值本来都是1,但因为冲突所以变成了2 3 4。

如何确定具体存放在哪个相邻位置里,与查找哈希表时的探测方法有关:
①线性探测法—— di = 0, 1, 2, 3, …, m-1;即发⽣冲突时,每次往后探测相邻的下⼀个单元是否为空。我们把冲突的元素存储在高于当前hash地址且最邻近的空位置里,如下图中的1、68、27,他们的hash值本来都是1,但因为冲突所以变成了2 3 4。
②平⽅探测法。当di = 02, 12, -12, 22, -22, …, k2, -k2时,称为平⽅探测法,⼜称⼆次探测法其中k≤m/2。我们把冲突的元素存储当前hash地址加减k ^ 2的位置。
③伪随机序列法。di 是⼀个伪随机序列,如 di= 0, 5, 24, 11, …
在这里插入图片描述
在这里插入图片描述

排序

在这里插入图片描述

插入排序

将元素插入有序区间时,可使用二分查找来优化。
在这里插入图片描述
在这里插入图片描述

希尔排序

希尔排序:先将待排序表分割成若⼲形如 L[i, i + d, i + 2d,…, i + kd] 的“特殊”⼦表,对各个⼦表分别进⾏直接插⼊排序。缩⼩增量d,重复上述过程,直到d=1为⽌。
初始增量选择n/2,每次迭代增量减半

在这里插入图片描述
在这里插入图片描述

冒泡排序

按照某种大小规则连续交换相邻两个元素的位置,使最大或最小的元素冒泡到序列首部或尾部,然后对剩余序列重复冒泡操作。
在这里插入图片描述

快速排序

在一段序列中随便选一个数,不妨计这个数为v,然后对序列元素进行一系列交换操作,使v左边的元素均小于v,v右边的元素均大于v。这样就把序列分成了三段,左边的都小于v,中间的都等于v,右边的都大于v,对左右子序列递归上述操作,即可完成排序。

在这里插入图片描述

排序不稳定。不适用链表。

时间复杂度=O(n*递归层数)
最好时间复杂度=O(nlog2n)
最坏时间复杂度=O(n2)
平均时间复杂度=O(nlog2n)

空间复杂度=O(递归层数)
最好空间复杂度=O(log2n)
最坏空间复杂度=O(n)

若序列原本就有序或逆序,则时、空复杂度最⾼(可优化,尽量选择可以把数据中分的枢轴元素。)

选择排序

遍历一个序列,选出最小的数把它挪动到序列头部。然后对除首部以外的剩余序列迭代上述操作,即可完成排序。
在这里插入图片描述

堆排序

堆是一种完全二叉树,对于每一个子树来说,都满足这样一个性质:子树的根节点的值是该子树所有结点的最大值或最小值。

用顺序表存堆比较方便。

堆的插入和删除就是简单的pushup和pushdown操作,建立堆可以看作是把一系列元素插入一个空堆。

借助堆的特性实现排序,称作堆排序。
在这里插入图片描述

归并排序

归并排序的内容:对于一个序列,把它分成左右两部分,然后对左右子序列分别递归调用归并排序,然后把左右两个有序的子序列合并为一个有序的序列。
在这里插入图片描述

基数排序

在这里插入图片描述
假设关键字可以拆成d个部分,每个部分可能取得r个值,总共有n个元素,那么:

  • 需要 r 个辅助队列,空间复杂度 = O®
  • ⼀趟分配O(n),⼀趟收集O®,总共 d 趟分配、收集,总的时间复杂度=O(d(n+r))

在这里插入图片描述

外部排序

指要排序的数据存储在外存中,也就是磁盘中。

磁盘的读/写以“块”为单位数据读⼊内存后才能被修改修改完了还要写回磁盘

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/996576.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Ae 效果:CC Snowfall

模拟/CC Snowfall Simulation/CC Snowfall CC Snowfall&#xff08;CC 飘雪&#xff09;可用来模拟带景深、光效和运动模糊的雪花飘落效果。 ◆ ◆ ◆ 效果属性说明 Flakes 雪花 用于设置场景中雪花的数量。 默认值 10000。 Size 大小 用于设置雪花的大小。 默认值 3.00。 …

iOS IdiotAVplayer实现视频分片缓存

文章目录 IdiotAVplayer 实现视频切片缓存一 iOS视频边下边播原理一 分片下载的实现1 分片下载的思路2 IdiotAVplayer 实现架构 三 IdiotAVplayer 代码解析IdiotPlayerIdiotResourceLoaderIdiotDownLoader IdiotAVplayer 实现视频切片缓存 一 iOS视频边下边播原理 初始化AVUR…

Kafka3.0.0版本——消费者(offset的默认维护位置)

目录 一、offset的默认维护位置1.1、offset的默认维护位置概述1.2、offset的默认维护位置图解 二、消费者offset的案例 一、offset的默认维护位置 1.1、offset的默认维护位置概述 Kafka0.9版本之前&#xff0c;consumer默认将offset保存在Zookeeper中。从Kafka0.9版本开始&am…

强大的JTAG边界扫描(2):BSDL文件介绍

文章目录 1. 什么是BSDL文件&#xff1f;2. BSDL文件的获取方式1&#xff1a;BSDL Library方式2&#xff1a;各芯片的官方网站Xilinx BSDL文件获取Altera BSDL文件获取Microsemi FPGA BSDL文件获取ST BSDL文件获取 3. BSDL文件示例4. BSDL文件的应用 1. 什么是BSDL文件&#xf…

C语言_指针(1)

文章目录 前言一、指针数组1.1利用指针数组模拟出二维数组 二、数组指针2.1数组名是数组首元素的地址2.2 二维数组传参2.3 一级指针传参2.4 二级指针传参 三. 函数指针四 . typedef 重命名 前言 指针数组是由指针组成的数组。它的每个元素都是一个指针&#xff0c;可以指向任何…

【算法与数据结构】530、LeetCode二叉搜索树的最小绝对差

文章目录 一、题目二、解法三、完整代码 所有的LeetCode题解索引&#xff0c;可以看这篇文章——【算法和数据结构】LeetCode题解。 一、题目 二、解法 思路分析&#xff1a;二叉搜索树的性质是左子树的所有节点键值小于中间节点键值&#xff0c;右子树的所有节点键值大于中间节…

【Spring面试】三、Bean的配置、线程安全、自动装配

文章目录 Q1、什么是Spring Bean&#xff1f;和对象有什么区别Q2、配置Bean有哪几种方式&#xff1f;Q3、Spring支持的Bean有哪几种作用域&#xff1f;Q4、单例Bean的优势是什么&#xff1f;Q5、Spring的Bean是线程安全的吗&#xff1f;Q6、Spring如何处理线程并发问题&#xf…

uview 组件 u-form-item 点击事件

问题 click"showCalendar(false)"点击没反应 原因&#xff1a; 组件未定义此事件&#xff0c;可使用原生点击事件.native click.native"showCalendar()" <u-form-item label"开始时间" label-width"150" right-icon"arrow…

戳气球00

题目链接 戳气球 题目描述 注意点 求戳破所有的气球所能获得硬币的最大数量0 < nums[i] < 1001 < n < 300 解答思路 初始只想到深度优先遍历暴力搜索所有情况找到获得硬币的最大数量&#xff0c;但是时间复杂度很高一定会超时参照题解使用动态规划解决本题&am…

机器人中的数值优化(十五)——PHR增广拉格朗日乘子法

本系列文章主要是我在学习《数值优化》过程中的一些笔记和相关思考&#xff0c;主要的学习资料是深蓝学院的课程《机器人中的数值优化》和高立编著的《数值最优化方法》等&#xff0c;本系列文章篇数较多&#xff0c;不定期更新&#xff0c;上半部分介绍无约束优化&#xff0c;…

Python中的进度条显示方案

迷途小书童 读完需要 3分钟 速读仅需 1 分钟 大家好&#xff0c;我是迷途小书童! tqdm 是一个非常常用的 Python 进度条库&#xff0c;它可以在循环迭代和 IO 操作期间添加一个进度条&#xff0c;直观地显示循环迭代的进程。 tqdm 是在 2013 年发布的&#xff0c;目的是为 Pyth…

netrw模拟nerdtree的go命令连续打开多个文件

vim9自带的文件浏览器netrw功能很强大。过去用惯了nerdtree的我&#xff0c;对netrw的文件操作还要适应一些时间。 使用netrw一段时间后发现它没有nerdtree的go命令的替代操作&#xff0c;今天就自制一个。 一、制作go命令&#xff1a; nerdtree的go命令功能&#xff1a;就是…

NetSuite 客户销售团队更新方法辨析

在NetSuite中如果想将销售团队与客户数据进行隔离&#xff0c;采用的方法是“在客户上定义销售团队&#xff0c;同时将销售团队成员的访问角色进行Employee Restrictions”。 其中&#xff0c;Employee Restrictions的主题我们过去发过几篇&#xff0c;大家可以参考。 NetSui…

【Blender】Blender入门学习

目录 0 参考视频教程0.1 Blender理论知识0.2 Blender上手实践0.3 FBX模型导入Unity 1 Blender的窗口介绍1.1 主界面1.2 模型编辑窗口 2 Blender的基本操作2.1 3D视图的平移2.2 3D视图的旋转2.3 3D视图的缩放2.4 修改快捷键2.5 使物体围绕选择的物体旋转2.6 四视图的查看2.7 局部…

Vivado 2017.04版本安装教程

文章目录 前言一、vivado 简介二、vivado 下载三、vivado 安装四、vivado 申请证书五、关闭升级提醒六、资源自取 前言 本文记录了在 windows 11 下安装 vivado 2017 的详细步骤。 一、vivado 简介 Vivado 是 Xilinx 公司于 2012 推出的新一代集成设计环境&#xff0c;虽然目…

【初阶C语言】操作符2---表达式求值

前言&#xff1a;本节重点介绍操作符的使用&#xff0c;如&#xff0c;优先级高低、类型转换等 一、逻辑操作符 前言&#xff1a;逻辑操作符包括逻辑与&#xff08;&&&#xff09;和逻辑或&#xff08;||&#xff09;&#xff0c;操作对象&#xff1a;两个 1.逻辑与&…

LeetCode 1359. Count All Valid Pickup and Delivery Options【动态规划,组合数学】1722

本文属于「征服LeetCode」系列文章之一&#xff0c;这一系列正式开始于2021/08/12。由于LeetCode上部分题目有锁&#xff0c;本系列将至少持续到刷完所有无锁题之日为止&#xff1b;由于LeetCode还在不断地创建新题&#xff0c;本系列的终止日期可能是永远。在这一系列刷题文章…

10.Xaml ListBox控件

1.运行界面 2.运行源码 a.Xaml 源码 <Grid Name="Grid1"><!--IsSelected="True" 表示选中--><ListBox x:Name="listBo

腾讯云免费SSL证书申请流程(图文教程)

2023腾讯云免费SSL证书申请流程&#xff0c;一个腾讯云账号可以申请50张免费SSL证书&#xff0c;免费SSL证书为DV证书&#xff0c;仅支持单一域名&#xff0c;申请腾讯云免费SSL证书3分钟即可申请成功&#xff0c;免费SSL证书品牌为TrustAsia亚洲诚信&#xff0c;腾讯云百科分享…

coderforces round 894(div.3)

Problem - A - Codeforces AC代码: #include<iostream> #include<algorithm> #include<cstring> #include<cmath> #include<queue> #include<set> #include<vector> #define endl \n //#define int long long using namespace std…