11.28~11.29基本二叉树的性质、定义、复习;排序算法;堆

完全二叉树(Complete Binary Tree)是一种特殊的二叉树结构,它具有以下特点:

  1. 所有的叶子节点都集中在树的最后两层;
  2. 最后一层的叶子节点都靠左排列;
  3. 除了最后一层,其他层的节点数都达到最大值。

满二叉树(Full Binary Tree),又称为真二叉树,是一种特殊的完全二叉树结构,它具有以下特点:

  1. 所有的叶子节点都在同一层;
  2. 每个非叶子节点都有两个子节点;
  3. 所有节点的子节点数都为0或2。

满二叉树是完全二叉树的一种特殊情况,每个非叶子节点都有两个子节点,而完全二叉树可以有一个或没有一个子节点。

树的定义,遍历,输入构建,一些递归复习(求叶子节点,数的高度)

ABC##DE#G##F###

5

第二次实验——二叉树中序遍历

ABD##FE###CG#H##I##

DBEFAGHCI

第十一周,后序+中序确定二叉树

树的性质

第二次实验的思考题

一棵非空二叉树,若后序遍历与中序遍历的序列相同,则该二叉树所有结点均无右孩子。

非空的二叉树一定满足:某结点若有左孩子,则其中序前驱一定没有右孩子。

二分查找法

二叉搜索树复习

寻找公共祖先

排序算法

第二次实验——快速排序的过程

5
4 5 3 2 1

输出

2 1 3 4 5 
1 2 3 4 5 
1 2 3 4 5 
1 2 3 4 5 
1 2 3 4 5 
插入排序还是归并排序

10
3 1 2 8 7 5 9 4 6 0
1 2 3 7 8 5 9 4 6 0

Insertion Sort
1 2 3 5 7 8 9 4 6 0

10
3 1 2 8 7 5 9 4 0 6
1 3 2 8 5 7 4 9 0 6

Merge Sort
1 2 3 8 4 5 7 9 0 6

插入排序,冒泡排序,选择排序,堆排序,归并排序

第八周习题——冒泡排序

第九周习题——二路归并排序

归并排序,逆序对

第七周——插入排序

结构体排序

第九周习题——成绩排名

第八周习题——小球装箱

排序算法性质

合并排序算法是稳定的排序方法。

直接插入排序在最好的情况下时间复杂度为O(n)

直接插入排序是稳定的

逆序对,倍数对

堆的调整,构建

调整

void shiftup(int child) {//在末尾插入一个孩子,然后就这个孩子一直往上调整,这样的话调整路径都满足堆的性质int parent = (child - 1) / 2;while (child > 0) {if (arr[parent] > arr[child]) {break;}else {swap(arr[parent], arr[child]);child = parent;//往上调整一步parent = (child - 1) / 2;//这里是先调整了孩子指针,所以这时候的父母就是父母的父母}}
}
void shiftup(int child) {int parent = (child - 1) / 2;while (child > 0) {if (arr[parent] > arr[child]) { break; }//大顶堆,上面大,就不调整了else {swap(arr[parent], arr[child]);child = parent;parent = (child - 1) / 2;}}
}
//向上调整的话就是找到最后一个孩子,然后找到它的父母节点,孩子对应的父母节点是唯一的,所以可以直接比较
//直接比较完后直接交换,直到到底
//向下调整的话就是先找到堆顶元素,然后由于堆是完全二叉树,所以对应两个孩子,找到最小的孩子,然后调整
//调整后,使被调整的孩子作为父母节点,找到其左孩子节点
//即,向上调整只需要找到一个节点信息,即当下节点信息,就可以确定父母节点,单向比较即可
//而向下调整需要两个节点信息,一个是当下节点信息(父母节点),还要直到它是否有孩子,默认为左孩子,然后判断一下有没有右孩子
//由此向下递归进行需要两个信息,一个父母节点,一个孩子节点,递归时默认孩子节点为左孩子,2*cur+1,然后尝试找右孩子
//如果在下次递归时,左孩子越界,那就说明此时父母节点已是叶子节点,到底了,无法继续调整。
void shiftdown(int[]arr, int size, int parent) {int child = parent * 2 + 1;while (child < size) {if (child + 1 < size && arr[child + 1] > arr[child]) {child += 1;}if (arr[parent] < arr[child]) {swap(arr, parent, child);parent = child;//由此,完成向下移动,child = parent * 2 + 1;//孩子与父母指针都向下移动}else {return;}}
}
void shiftdown(int[]arr, int parent) {//父母直接,指向要交换的元素int child = 2 * parent + 1;//孩子指针,指向要交换的元素int size = arr.length();while (child < size) {//只要有这一步,就说明当下节点至少存在左孩子if (child + 1 < size && arr[child + 1] < arr[child]) {child += 1;//如果向右一个单位存在,就说明当下节点有右孩子,找最小的}//确定较小的孩子if (arr[parent] <= arr[child]) {break;}else {int t = arr[parent];parr[parent] = arr[child];arr[child] = t;parent = child;child = parent * 2 + 1;}}
}

如果左孩子存在,则child<size,不断进行操作,直到左孩子不存在

检测右孩子是否存在,找左右孩子中最小的孩子

堆的创建

这个就是先输入,输入一个数组,输入完后再开始调整,从最后一个非叶子结点开始,然后不断往上往回走,进行向下调整

public static void createHeap(int[] array) {// 找倒数第一个非叶子节点,从该节点位置开始往前一直到根节点,遇到一个节点,应用向下调整for(int root = (array.length-2)/2; root >= 0; root--){shiftDown(array, array.length, root);}
}

插入,边插边保持堆

int arr[100];
int siz = 0;
void shiftup(int child) {int parent = (child - 1) / 2;while (child > 0) {if (arr[parent] >= arr[child]) {break;}else {swap(arr[parent], arr[child]);child = parent;parent = (child - 1) / 2;}}
}
void insert(int num) {arr[siz++] = num;shiftup(siz - 1);
}

二叉树指针关系

对于二叉树的孩子双亲指针指引,如果是从1开始记录的,那么

左孩子结点索引 = 2 * i 右孩子结点索引 = 2 * i + 1

其中,i表示当前结点的索引位置。

当索引从1开始记录时,根节点的索引为1,其左孩子结点的索引为2,而右孩子结点的索引为3。对于任意结点i,其左孩子结点的索引位置为2 * i,右孩子结点的索引位置为2 * i + 1。

如果是从0开始记录的,

二叉树以数组形式存储时,一般约定根节点的索引位置为0,其左孩子结点的索引位置为1,右孩子结点的索引位置为2。对于任意结点i,其左孩子结点的索引位置为2 * i + 1,右孩子结点的索引位置为2 * i + 2。

堆的一些性质

下标从0开始计数的堆,大小为size时,其最后一个非叶子结点是(size-2)/2;

最后一个叶子结点的下标为size-1.

由于是下标从0,所以对结点i而言,其双亲结点下标为(i-1)/2

(如果下标从1开始,那么整体往右偏移一位)

所以对于下标为size-1的结点,它的双亲结点为(size-1-1)/2;

最大堆(大顶堆、max-heap)从根结点到其它任一结点的路径上的所有结点值是从大到小排列的。

第十二周堆的操作,堆的建立

找第k小

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Python 进阶(十二):随机数(random 模块)

《Python入门核心技术》专栏总目录・点这里 文章目录 1. 导入random库2. 常用随机数函数2.1 生成随机浮点数2.2 生成随机整数2.3 从序列中随机选择2.4 随机打乱序列3. 设置随机数种子4. 应用实例4.1 游戏开发4.2 数据分析4.3 加密与安全4.4 模拟实验

C++核心编程——运算符重载

C核心编程——运算符重载 运算符重载的方法运算符重载函数作成员函数与友元函数重载双目运算符重载单目运算符重载流插入运算符和"<<"和流提取运算符">>"重载流插入运算符和"<<"流提取运算符">>" 运算符重载的…

finebi 新手入门案例

finebi 新手入门案例 连锁超市销售数据分析 步骤&#xff1a; 准备公共数据新建分析主题处理数据在数据中分析在图形中分析数据大屏 准备公共数据 点击公共数据 点击新建文件夹 修改文件夹名称 上传数据 鼠标悬停在文件夹上&#xff0c;右侧出现 鼠标悬停在文件夹上&#x…

Ubuntu中MySQL安装与使用

一、安装教程&#xff1a;移步 二、通过sql文件创建表格&#xff1a; 首先进入mysql&#xff1a; mysql -u 用户 -p 回车 然后输入密码source sql文件&#xff08;路径&#xff09;;上面是sql语句哈&#xff0c;所以记得加分号。 sql文件部分截图&#xff1a; 创建成功后的部…

《opencv实用探索·七》一文看懂图像卷积运算

1、图像卷积使用场景 图像卷积是图像处理中的一种常用的算法&#xff0c;它是一种基本的滤波技术&#xff0c;通过卷积核&#xff08;也称为滤波器&#xff09;对图像进行操作&#xff0c;使用场景如下&#xff1a; 模糊&#xff08;Blur&#xff09;&#xff1a; 使用加权平…

与原有视频会议系统对接

要实现与原有视频会议系统对接&#xff0c;需要确保通信协议的一致性。连通宝视频会议系统可与第三方视频会议系统对接。实现与第三方会议系统对接还可以使用会议室连接器&#xff0c;可以确保不同系统之间的数据传输和交互。 具体对接流程可能因不同品牌和类型的视频会议系统而…

蓝桥杯第四场双周赛(1~6)

1、水题 2、模拟题&#xff0c;写个函数即可 #define pb push_back #define x first #define y second #define int long long #define endl \n const LL maxn 4e057; const LL N 5e0510; const LL mod 1e097; const int inf 0x3f3f; const LL llinf 5e18;typedef pair…

BEV+Transformer架构加速“上车”,智能驾驶市场变革开启

BEVTransformer成为了高阶智能驾驶领域最为火热的技术趋势。 近日&#xff0c;在2023年广州车展期间&#xff0c;不少车企及智能驾驶厂商都发布了BEVTransformer方案。其中&#xff0c;极越01已经实现了“BEVTransformer”的“纯视觉”方案的量产&#xff0c;成为国内唯一量产…

Leetcode-二叉树oj题

1.二叉树的前序遍历 144. 二叉树的前序遍历https://leetcode.cn/problems/binary-tree-preorder-traversal/这个题目在遍历的基础上还要求返回数组&#xff0c;数组里面按前序存放二叉树节点的值。 既然要返回数组&#xff0c;就必然要malloc一块空间&#xff0c;那么我们需…

C# WPF上位机开发(第一个应用)

【 声明&#xff1a;版权所有&#xff0c;欢迎转载&#xff0c;请勿用于商业用途。 联系信箱&#xff1a;feixiaoxing 163.com】 万事开头难&#xff0c;很多事情都是难在第一步。走出了这第一步&#xff0c;回过头看以前走的每一步&#xff0c;发现其实也不难。用c# wpf编写界…

系列九、声明式事务(xml方式)

一、概述 声明式事务(declarative transaction management)是Spring提供的对程序事务管理的一种方式&#xff0c;Spring的声明式事务顾名思义就是采用声明的方式来处理事务。这里所说的声明&#xff0c;是指在配置文件中声明&#xff0c;用在Spring配置文件中声明式的处理事务来…

Go 数字类型

一、数字类型 1、Golang 数据类型介绍 Go 语言中数据类型分为&#xff1a;基本数据类型和复合数据类型基本数据类型有&#xff1a; 整型、浮点型、布尔型、字符串复合数据类型有&#xff1a; 数组、切片、结构体、函数、map、通道&#xff08;channel&#xff09;、接口 2、…

excel合并单元格教程

在表格里&#xff0c;总是会遇到一级表格、二级表格的区别&#xff0c;这时候一级表格会需要合并成一个大格子&#xff0c;那么excel如何合并单元格呢&#xff0c;其实使用快捷键或者功能键就可以了。 excel如何合并单元格&#xff1a; 1、首先我们用鼠标选中所有要合并的单元…

计算机网络之数据链路层

目录 一、数据链路层的几个共用问题 1.1数据链路和帧 1.2三个基本问题 二、点对点协议PPP 2.1PPP协议的特点 2.2PPP协议的帧格式 2.3 PPP协议的工作状态 三、使用广播信道的数据链路层 3.1局域网的数据链路层 数据链路层的两个子层 3.2CSMA/CD协议 3.3使用集线器的…

云服务器anaconda(py39)+pytorch1.12.0(cu113)

用xshell连接ip地址&#xff0c;端口号22&#xff0c;输入用户密码 查看当前版本 conda -V conda info --envs 如果不是需要的版本&#xff0c;使用 anaconda-clean --yes rm -rf anaconda3 删除文件夹 安装anaconda 2022 10 py3.9 wget https://repo.anaconda.com/archi…

干货:如何拯救程序员的苦恼?

本站的同志大多都是IT行业的从业者。今天博主给大家推荐几个帮助程序员解决烦恼的网站&#xff0c;大家一定要收藏哦&#xff01; 目录 1. 图标平台——ByteDance IconPark 2. 进制转换——so json在线工具 3. 代码高亮——CodeInWord 4. 取名利器——codelf 5. 颜色图签—…

外包搞了3年,感觉技术退步很明显......

先说情况&#xff0c;大专毕业&#xff0c;18年通过校招进入湖南某软件公司&#xff0c;干了接近6年的功能测试&#xff0c;今年年初&#xff0c;感觉自己不能够在这样下去了&#xff0c;长时间呆在一个舒适的环境会让一个人堕落!而我已经在一个企业干了四年的功能测试&#xf…

uniapp上架app store详细攻略

目录 uniapp上架app store详细攻略 前言 一、登录苹果开发者网站 二、创建好APP 前言 uniapp开发多端应用&#xff0c;打包ios应用后&#xff0c;会生成一个ipa后缀的文件。这个文件无法直接安装在iphone上&#xff0c;需要将这个ipa文件上架app store后&#xff0c;才能通…

R语言实操记录——R包无法安装,报错:Warning in system(cmd) : ‘make‘ not found

R语言 R语言实操记录——R包无法安装&#xff0c;报错&#xff1a;Warning in system(cmd) : ‘make‘ not found 文章目录 R语言一、起因二、具体步骤2.1、确认问题源2.2、安装RTools2.3、与R(/Rstudio)绑定2.4、验证可行性 三、疑惑 一、起因 R语言在包的安装上是真的方便&…

Visual Studio通过ClaudiaIDE插件设置背景图片

首先&#xff0c;在VS菜单栏上选择扩展-管理扩展&#xff0c;搜索插件为 ClaudiaIDE&#xff0c; 下载完成之后&#xff0c;关闭VS&#xff0c;点击Modify按钮安装&#xff1a; 等待安装完成&#xff0c;进入 VS , 打开 工具----选项---- ClauDiaIDE 界面 这个是背景色调 我选的…