12.13_黑马数据结构与算法笔记Java

news2024/11/18 14:42:17

目录

098 堆 heapify 3

099 堆 增删替换

100 堆 e01 堆排序

100 堆e02 求数组第k大元素

100 堆e03 求数据流第k大元素

100 堆e04 求数据流中位数1

100 堆e04 求数据流中位数2

100 堆e04 求数据流中位数3

101 二叉树 概述

102 二叉树 深度优先遍历

103 二叉树 前中后遍历 递归实现

104 二叉树 前中后遍历 非递归1

105 二叉树 前中后遍历 非递归2

106 二叉树 前中后遍历 非递归3

107 二叉树 前中后遍历 非递归4

108 二叉树 e04 对称二叉树

109 二叉树 e05 最大深度 解法1

110 二叉树 e05 最大深度 解法2

111 二叉树 e05 最大深度 解法3

112 二叉树 e06 最小深度

113 二叉树 e07 翻转二叉树

114 二叉树 e08 根据后缀表达式建树

115 二叉树 e09 根据前中遍历结果建树

116 二叉树 e010 根据中后遍历结果建树

117 二叉搜索树 概述

118 二叉搜索树 get

119 二叉搜索树 泛型key


098 堆 heapify 3

099 堆 增删替换

-------------------------------------------------------------------------------------------------------------------------------- 

up方法里面,child =parent:因为如果没有退出循环,就还要为下一次的比较做好准备,因此要改变child的值,那改变成什么样子呢?就变成这一轮parent的样子。 

---------------------------------------------------------------------------------------------------------------------------------

100 堆 e01 堆排序

100 堆e02 求数组第k大元素

100 堆e03 求数据流第k大元素

100 堆e04 求数据流中位数1

100 堆e04 求数据流中位数2

---------------------------------------------------------------------------------------------------------------------------------

代码解释:利用布尔类型判断是大顶堆还是小顶堆,减少重复的代码。

别的扩容代码:

---------------------------------------------------------------------------------------------------------------------------------

经过修改: 

100 堆e04 求数据流中位数3

---------------------------------------------------------------------------------------------------------------------------------

比较器 

 

-------------------------------------------------------------------------------------------------------------------------------- 

101 二叉树 概述

102 二叉树 深度优先遍历

如何记忆:

前中后,则记忆中间的部分,

前对应中间访问的是左,

中对应中间访问的是中,

后对应中间访问的是右。其余的就按照左中右进行补充。 

理解:

前序遍历,从左向右走,去的时候遇到啥遍历啥

中序遍历:从左向右走,去的时候不要,回来的时候,遇到啥遍历啥

后序遍历:从左向右,去的时候不要,回来的时候,真正结束了,才遍历,比如像这个1,我确实后来经过了它,但是其实我们的缘分还未尽。缘分尽了,才遍历。

103 二叉树 前中后遍历 递归实现

104 二叉树 前中后遍历 非递归1

用栈记得来时路。 

105 二叉树 前中后遍历 非递归2

中序

前序  

106 二叉树 前中后遍历 非递归3

后序遍历中,要增加一些细节去限定条件。当peek的右子树为null的时候,因为左子树已经搞完,而又没有右子树,就可以直接弹出peek。当peek的右子树不为null的时候,就要去判断来时路到底是走左子树还是右子树,因为要判断我现在走回来这条路到底是不是从右子树这边走回来(也就是比较弹栈出来的那个数字是不是peek的右子树),如果弹栈的是7,就说明右孩子都处理完了。如果都不是以上的情况, 则标记peek的右子树为curr,进入下一轮的比较。

107 二叉树 前中后遍历 非递归4

108 二叉树 e04 对称二叉树

109 二叉树 e05 最大深度 解法1

110 二叉树 e05 最大深度 解法2

111 二叉树 e05 最大深度 解法3

112 二叉树 e06 最小深度

-------------------------------------------------------------------------------------------------------------------------------- 

如果是null的话,就不应该比较了。

-------------------------------------------------------------------------------------------------------------------------------- 

113 二叉树 e07 翻转二叉树

114 二叉树 e08 根据后缀表达式建树

115 二叉树 e09 根据前中遍历结果建树

116 二叉树 e010 根据中后遍历结果建树

117 二叉搜索树 概述

118 二叉搜索树 get

 如果函数最后一步是调用自己,那就是伪递归,尽可能将这个形式转化为非递归形式。

非递归,以下

119 二叉搜索树 泛型key

为了让泛型key进行大小比较,就要实现接口,可以搞一个泛型,或者两个泛型。

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

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

相关文章

2024年顶级的9个 Android 数据恢复工具(免费和付费)

不同的事情可能会损坏您的Android手机并导致您丢失数据。但大多数时候,您可以使用取证工具恢复部分或全部文件。 问题可能来自手机的物理损坏、磁盘的逻辑故障、完整的系统擦除,或者只是简单的粗心大意。 但是,无论数据丢失的原因是什么&am…

路由基本原理

目录 一、路由器概述 二、路由器的工作原理 三、路由表的形成 四、路由配置 1.连接设备 2.进入系统模式 3.进入接口模式 4.配置网络 5.下一跳的设置 6.设置浮动路由 7.设置默认路由 一、路由器概述 路由器(Router)是一种用于连接不同网络或子…

MySQL和Redis有什么区别?

目录 一、什么是MySQL 二、什么是Redis 三、MySQL和Redis的区别 一、什么是MySQL MySQL是一种开源的关系型数据库管理系统(RDBMS),它是最流行的数据库之一。MySQL以其高性能、可靠性和易用性而闻名,广泛应用于各种Web应用程序…

单片机的低功耗模式介绍

文章目录 简介一、功耗来源说明1.1、芯片工作模式1.2、静态损耗1.3、I/O额外损耗1.4、动态损耗 二、功耗如何测量三、降低功耗有什么方法3.1、选取合适的芯片工作模式3.2、降低工作频率3.3、关闭不需要使用的外设3.4、 降低静态电流损耗3.5、 周期采集供电3.6、 设置IO口状态 四…

MYSQL各种日志

感谢B站up主的视频分享 黑马程序员 MySQL数据库入门到精通,从mysql安装到mysql高级、mysql优化全囊括_哔哩哔哩_bilibili

FMETP STREAM 2.0

FMETPSTREAM简化了Unity3D中的直播,无需编码。设置和测试仅需5分钟。 "编码器模块"将Unity游戏视图、网络摄像头、桌面、声音和麦克风输入转换为字节数据,使其完美适用于各种流媒体场景。 优化的网络模块支持Server-clients连接类型,并允许您使用单个命令向 Serve…

el-date-picker限制选择7天内禁止内框选择

需求&#xff1a;elementPlus时间段选择框需要满足&#xff1a;①最多选7天时间。②不能手动输入。 <el-date-picker v-model"timeArrange" focus"timeEditable" :editable"false" type"datetimerange" range-separator"至&qu…

六.聚合函数

聚合函数 1.什么是聚合函数1.1AVG和SUM函数1.2MIN和MAX函数1.3COUNT函数 2.GROUP BY2.1基本使用2.2使用多个列分组2.3GROUP BY中使用WITH ROLLUP 3.HAVING3.1基本使用3.2WHERE和HAVING的区别 4.SELECT的执行过程4.1查询的结构4.2SELECT执行顺序4.3SQL执行原理 1.什么是聚合函数…

微服务实战系列之MQ

前言 从今天起&#xff0c;席卷北国的雪&#xff0c;持续了一整天&#xff0c;北京也不例外。这场意外的寒潮&#xff0c;把整个冬天渲染的格外cool。当然你可以在外面打雪仗、堆雪人、拉雪橇&#xff0c;也可以静坐屋内&#xff0c;来一场围炉煮茶的party。此刻&#xff0c;冬…

在IDEA中配置Git的Push键

前言 笔者在重新安装IDEA过程中需要重新绑定了Git&#xff0c;发现提交代码过程中push键消失了&#xff0c;所以笔者就以这篇文章记录一下Git配置push键的详细过程。 注意笔者当前IDEA版本为2019&#xff0c;可能和读者有所区别&#xff0c;但是操作思路是差不多的。 操作步…

Ubuntu22.04切换用户

一、只有一个用户时没有切换用户菜单项 1、用户信息 cat /etc/passwd 2、系统菜单 二、添加用户 添加新用户ym&#xff0c;全名yang mi 三、有两个及以上的用户时出现切换用户菜单项 1、用户信息 cat /etc/passwd 2、系统菜单 四、切换用户 1、点击上图中Switch User …

Python数据科学视频讲解:Python的数据运算符

2.9 Python的数据运算符 视频为《Python数据科学应用从入门到精通》张甜 杨维忠 清华大学出版社一书的随书赠送视频讲解2.9节内容。本书已正式出版上市&#xff0c;当当、京东、淘宝等平台热销中&#xff0c;搜索书名即可。内容涵盖数据科学应用的全流程&#xff0c;包括数据科…

关于标准库中的list(涉及STL的精华-迭代器的底层)

目录 关于list list常见接口实现 STL的精华之迭代器 关于list list的文档介绍 1. list是可以在常数范围内在任意位置进行插入和删除的序列式容器&#xff0c;并且该容器可以前后双向迭代。 2. list的底层是双向链表结构&#xff0c;双向链表中每个元素存储在互不相关的独立…

为什么要使用国际语音群呼系统?

1.降本增效 通过批量导入客户的电话号码&#xff0c;由系统自动完成批量呼叫&#xff0c;企业可以节省人工拨号的费用&#xff0c;高效助力企业业务增长&#xff1b; 2.降低流失 通过批量群呼&#xff0c;企业可以724小时高并发无故障运行&#xff0c;智能锁定意向客户&…

java代码编写twitter授权登录

在上一篇内容已经介绍了怎么申请twitter开放的API接口。 下面介绍怎么通过twitter提供的API&#xff0c;进行授权登录功能。 开发者页面设置 首先在开发者页面开启“用户认证设置”&#xff0c;点击edit进行信息编辑。 我的授权登录是个网页&#xff0c;并且只需要进行简单的…

UML概扩知识点

UML是一个重要的知识点&#xff0c;考察的频度也很高。我们需要了解的是UML的一系列的图&#xff0c;红框里的是最核心的。 其次是对各种关系有了解&#xff08;红框里的&#xff1a; 依赖关系&#xff0c;关联关系&#xff0c;泛化关系&#xff0c;实现关系&#xff09; UM…

01.前言

前言 1.什么是前端开发 前端开发是创建 Web 页面或 app 等前端界面呈现给用户的过程核心技术&#xff1a;HTML&#xff0c;CSS&#xff0c;JavaScript 以及衍生出的各种技术&#xff0c;框架等 2.前端开发应用场景 3.前端职业路线 4.什么是CS架构与BS架构 介绍 应用软件&a…

项目总体测试计划书-word原件

编写此测试方案的目的在于明确测试内容、测试环境、测试人员、测试工作进度计划等&#xff0c;以保证测试工作能够在有序的计划安排进行。

【如何理解select、poll、epoll?】

如何理解select、poll、epoll&#xff1f; select、poll、epollselectpollepoll 知识扩展三者之间的主要区别是什么&#xff1f;epoll的两种模式是什么&#xff1f; select、poll、epoll select、poll、epoll都是Linux中常见的I/O多路复用技术&#xff0c;他们可以用于同时监听…

使用ffmpeg命令进行视频格式转换

1 ffmpeg介绍 FFmpeg 是一个非常强大和灵活的开源工具集&#xff0c;用于处理音频和视频文件。它提供了一系列的工具和库&#xff0c;可以用于录制、转换、流式传输和播放音频和视频。 FFmpeg 主要特点如下&#xff1a; 格式支持广泛&#xff1a;FFmpeg 支持几乎所有的音频和视…