Java数据结构与Java算法学习Day05---二叉树(简略笔记记录)

news/2024/5/2 10:35:03/文章来源:https://blog.csdn.net/xiaoxixicc/article/details/128184391

目录

一、二叉树 79

1.1树的基本定义79 

1.2数的相关术语 80

1.3二叉树的基本定义 81

1.4二叉查找树的创建 82

1.4.1二叉树查找树创建---插入方法(put) 83

1.4.2二叉树查找树创建---获取方法(get)84

1.4.3二叉树查找树创建---删除方法(delete)85

1.4.4代码的测试 86

1.5二叉查找树其他便捷方法 87

1.5.1查找二叉树中最小的键 87

1.5.2查找二叉树中最大的键 88

1.6二叉树的基础遍历 89

1.6.1二叉树---前序遍历 90

1.6.2二叉树---中序遍历 91

1.6.3二叉树---后序遍历 92

1.7二叉树---层序遍历 93

1.8最大深度问题 94

1.9折纸问题 95


一、二叉树 79

1.1树的基本定义79 

数组:

查询的效率比较快,原因是其地址是连续的,根据索引能够快速的查找到。

增删的效率比较慢,每次的增删需要涉及到大量数据的移动。 

链表:

查询的效率比较慢,是因为需要从头结点开始进行查询。  

增删的效率比较快,不需要大量的数据移动,只需要在插入的结点处断开后,然后进行插入即可。

 树:结合了链表和数组的。

1.2数的相关术语 80

 结点的度: 

叶结点:

 结点的层序编号:

数的度:

注:根结点的度不一定是最大的

孩子结点、双亲结点、兄弟结点:

1.3二叉树的基本定义 81

二叉树就是度不超过2的数(每个结点最多有两个子结点) 

二叉查找树:左子结点小于右子结点。.

堆:左子结点和右子结点之间没有大小区分。

 

 两个特殊的二叉树:

满二叉树:

 每一层的结点的个数都能达到2^(k-1)  k:层数

完全二叉树:

1.4二叉查找树的创建 82

通过键值对的形式 进行查询。

1.4.1二叉树查找树创建---插入方法(put) 83

插入方法put实现思想:

本部分代码在/tree/BinaryTree中。

1.4.2二叉树查找树创建---获取方法(get)84

查询方法get实现思想:

1.4.3二叉树查找树创建---删除方法(delete)85

删除原来的二叉树之后,需要有一个新的再次替换。这个新的替换是谁比较合适呢?

如何确定这个删除后新替换的元素呢?

  找到被删除元素的右子树中最小结点,作为替换位置的结点元素。

1.4.4代码的测试 86

本部分代码在/test/BinaryTreeTest中

1.5二叉查找树其他便捷方法 87

1.5.1查找二叉树中最小的键 87

本部分代码在/test/BinaryTree中。最左端的就是最小的键

1.5.2查找二叉树中最大的键 88

本部分代码在/test/BinaryTree中。最右端的就是最大的键

1.6二叉树的基础遍历 89

二叉树的基本遍历的基本的概念: 

遍历方法转换为:搜索路径问题。

搜索路径有三种:(其中最重要的是中序遍历)

示例:

1.6.1二叉树---前序遍历 90

前序遍历代码:/tree/BinaryTree

测试代码:/test/BinaryTreeErgodicTest

1.6.2二叉树---中序遍历 91

中序遍历代码:/tree/BinaryTree

测试代码:/test/BinaryTreeErgodicTest

1.6.3二叉树---后序遍历 92

后序遍历代码:/tree/BinaryTree

测试代码:/test/BinaryTreeErgodicTest

1.7二叉树---层序遍历 93

层序遍历:是从上到下,然后在每层进行从左到右进行查询,进行队列进入。

层序遍历代码:/tree/BinaryTree

测试代码:/test/BinaryTreeErgodicTest

1.8最大深度问题 94

待看 

1.9折纸问题 95

待看

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

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

相关文章

【测试沉思录】23. 如何实现基于场景的接口自动化测试用例?

作者:陈爱娇 编辑:毕小烦 自动化本身是为了提高工作效率,不论选择何种框架,何种开发语言,我们最终想实现的效果,就是让大家用最少的代码,最小的投入,完成自动化测试的工作。 基于这…

K-Means++代码实现

K-Means代码实现 数据集 https://download.csdn.net/download/qq_43629083/87246495 import pandas as pd import numpy as np import random import math %matplotlib inline from matplotlib import pyplot as plt# 按文件名读取整个文件 data pd.read_csv(data.csv)class…

学编程:Python入门考级必备[11]

目录 1.查找字符串 2.字符串的格式化 3.字符串的转义字符 \ \" 4. 修改字符串 5.字符串连接与分割 附件代码: 炼 知识模块(11) 名符其实--字符串 1.查找字符串 # 1.1用 in 函数 a aa in acacacacaabaac print(a) # 1.2 用index 找不到就报错 b h…

民办二本程序员阿里、百度、平安等五厂面经,5 份 offer(含真题)

昨天小休,一位高中同学联系了我,说是要请我吃饭,有这种好事,我当然是毫不犹豫的答应了啦! 等等...会不会是找我借钱的? 好慌,怎么办?已经答应过去了。 在后面的交谈中,…

Odoo丨如何在明细行中添加复选框?

最近,在项目实际业务中遇到需要对明细订单添加复选框和按钮进行操作的需求。 起初在拿到需求时,我联想到Odoo默认tree视图是有复选框和操作按钮的功能,于是查看了源码,确认了这个想法。 因为这个是属于字段中one2many 关系属性来…

三车道交通流元胞自动机研究(matlab代码实现)

👨‍🎓个人主页:研学社的博客 💥💥💞💞欢迎来到本博客❤️❤️💥💥 🏆博主优势:🌞🌞🌞博客内容尽量做到思维缜…

中国电信移动物联网发展成果与创新实践 ,干货满满

近日,首届移动物联网大会(2022)(以下简称“大会”)在江苏省无锡市举办。本次大会由工信部指导,中国信息通信研究院(以下简称“中国信通院”)、中国通信学会、无锡市人民政府、人民邮…

大数据学习:进程管理

文章目录一、进程ID(PID)二、查看进程1、进程查看命令-ps(1)命令作用(2)参数说明(3)操作案例2、Linux进程状态3、观察进程变化命令 -top(1)参数选项&#xff…

超声功率放大器在MEMS超声测试中的应用

MEMS(微机电系统)技术的不断发展,目前已经广泛应用在生物、航空、医学、航天等多领域。MEMS传感器即微机电系统(Micro-electroMechanicalSystems),是指精密机械系统和微电子电路技术结合发展出来的一项工程…

【正点原子FPGA连载】第二十八章 以太网ARP测试实验 摘自【正点原子】DFZU2EG/4EV MPSoC 之FPGA开发指南V1.0

1)实验平台:正点原子MPSoC开发板 2)平台购买地址:https://detail.tmall.com/item.htm?id692450874670 3)全套实验源码手册视频下载地址: http://www.openedv.com/thread-340252-1-1.html 第二十八章 以太…

【C++11多线程】线程同步之线程互斥:mutex、lock_guard

文章目录1.mutex2.锁双重判断3.lock_guard4.unique_lockunique_lock的构造函数1.mutex 头文件 #include <mutex> mutex 是一个类&#xff0c;其源码如下图所示。 互斥锁其实就是一个类对象&#xff0c;多个线程尝试用成员函数 lock() 来加锁&#xff0c;只有一个线程能…

自定义HandlerMethodArgumentResolver如何注册到springmvc框架里的

目录 1.DEBUG 注册代码 1.1 WebMvcConfigurerComposite 1.2 DelegatingWebMvcConfiguration 1.3 AutowiredAnnotationBeanPostProcessor 2.DEBUG调用代码 2.1 this.argumentResolvers 日常工作开发中&#xff0c;总有一些参数&#xff0c;在未传参数时&#xff0c;需要自定…

Web3中文|马斯克也疯狂?网红AI “ChatGPT”有多火?

一个名为“ChatGPT”的网红AI竟写出了毁灭人类的计划书。 计划书的步骤详细到入侵各国计算机系统、控制武器、破坏通讯、交通系统等等。和电影里的情节一模一样&#xff0c;甚至ChatGPT还给出了相应的Python代码。 诱导ChatGPT写下该计划的是一位名为扎克德纳姆&#xff08;Z…

计算机网络-网络层:IP协议

目录 一、IP协议格式 二、IP地址管理 1.动态地址分配&组建私网 1.1 动态地址分配DHCP 1.2 NAT技术组建私网 2. 早期网络划分方式 3. 当前网络划分方式CIDR方案 4. 特殊IP地址 5. 公网与私网&#xff08;外网与内网&#xff09; 6. 路由选择 网络层&#xff1a;负…

【win11内存占用高优化】未运行程序,系统内存占用50以上

这里写自定义目录标题前言打开控制面板找到电源键功能找到快速启动选项&#xff0c;取消勾选&#xff0c;确定win X以管理员身份打开powershell输入如下命令&#xff0c;回车关闭终端完成前言 windows11在未运行任何其他程序的情况下&#xff0c;内存占用超50%&#xff0c;可…

深入浅出java nio

Buffer 缓冲 为什么需要缓冲&#xff1f; 思考&#xff1a;没有buffer之前的读写。 子类 常见类型的缓冲 ByteBuffer public abstract class ByteBufferextends Bufferimplements Comparable<ByteBuffer> {}ByteBuffer是抽象类无法直接实例化&#xff0c;可以通过all…

研究 | CT图像迭代重建算法研究进展

上次讲到我实现了一下代数迭代重建&#xff08;ART&#xff09;&#xff0c;到周六开会的时候才大概了解了我的研究方向应该是统计迭代重建&#xff0c;一下子就把我给搞懵了。按照书上的说法&#xff0c;统计迭代法是在发射型CT&#xff08;SPECT和PET&#xff09;中应用广泛&…

[附源码]计算机毕业设计勤工俭学管理小程序Springboot程序

项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM mybatis Maven Vue 等等组成&#xff0c;B/S模式 M…

Docker学习4-常用命令之重要的容器命令

本文是Docker学习系列教程中的第四篇。本文是Docker常用命令中的重要命令。为什么说重要呢&#xff1f;因为这些命令&#xff0c;在以后开发过程中&#xff0c;会经常使用到。比如&#xff1a;怎么查看容器中运行的日志&#xff1f;怎么查看容器运行的进程&#xff1f;怎么导出…

【安全测试】渗透测试神器BurpSuite环境搭建

工欲善其事&#xff0c;必先利其器&#xff0c;要想更好的进行安全测试&#xff0c;就需要有一个趁手的工具&#xff0c;BurpSuite就是一个不错的选择&#xff0c;是广大安全测试工程师的必备工具&#xff0c;今天就带着大家把这个工具给装上&#xff0c;开启大家的安全测试之旅…