数据结构(七)——树结构(Tree) 之二叉树的常用操作

2024-03-31 19:58

本文主要是介绍数据结构(七)——树结构(Tree) 之二叉树的常用操作,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一.链式存储的二叉树的操作

1.遍历二叉树

  • 先序遍历:根-->左-->右
  • 中序遍历:左-->根-->右
  • 后序遍历:左-->右-->根
  • 层级遍历:逐层从左到输出

2.二叉树结点的查找 

结点的查找也可以分为先序查找,中序查找和后序查找。方式和遍历方式相似。

3.删除二叉树结点

  • 二叉树抽象类代码
package cn.kimtian.tree;/*** 链式存储的二叉树** @author kimtian*/
public class BinaryTree {/*** 根结点*/TreeNode root;/*** 设置根结点** @param root 根结点*/public void setRoot(TreeNode root) {this.root = root;}/*** 获取根结点** @return TreeNode 根结点*/public TreeNode getRoot() {return root;}/*** 先序遍历*/public void frontShow() {if (root != null) {root.frontShow();}}/*** 中序遍历*/public void middleShow() {if (root != null) {root.middleShow();}}/*** 后序遍历*/public void behindShow() {if (root != null) {root.behindShow();}}/*** 查找二叉树的结点--先序查找** @param i 查找的结点的值*/public TreeNode frontSearch(int i) {return root.frontSearch(i);}/*** 查找二叉树的结点--中序查找** @param i 查找的结点的值*/public TreeNode middleSearch(int i) {return root.middleSearch(i);}/*** 查找二叉树的结点--后序查找** @param i 查找的结点的值*/public TreeNode behindSearch(int i) {return root.behindSearch(i);}/*** 删除二叉树的结点/子树** @param i 查找的结点的值*/public void deleteTreeNode(int i) {if (root.value == i) {root = null;} else {root.deleteTreeNode(i);}}
}
  • 二叉树的结点
package cn.kimtian.tree;/*** 树里面的结点** @author kimtian*/
public class TreeNode {/*** 树里面的值,结点的权*/int value;/*** 左儿子*/TreeNode leftNode;/*** 右儿子*/TreeNode rightNode;public TreeNode(int value) {this.value = value;}public void setLeftNode(TreeNode leftNode) {this.leftNode = leftNode;}public void setRightNode(TreeNode rightNode) {this.rightNode = rightNode;}/*** 先序遍历--递归思想*/public

这篇关于数据结构(七)——树结构(Tree) 之二叉树的常用操作的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/865208

相关文章

MyBatis常用XML语法详解

《MyBatis常用XML语法详解》文章介绍了MyBatis常用XML语法,包括结果映射、查询语句、插入语句、更新语句、删除语句、动态SQL标签以及ehcache.xml文件的使用,感兴趣的朋友跟随小... 目录1、定义结果映射2、查询语句3、插入语句4、更新语句5、删除语句6、动态 SQL 标签7、ehc

使用Java填充Word模板的操作指南

《使用Java填充Word模板的操作指南》本文介绍了Java填充Word模板的实现方法,包括文本、列表和复选框的填充,首先通过Word域功能设置模板变量,然后使用poi-tl、aspose-words... 目录前言一、设置word模板普通字段列表字段复选框二、代码1. 引入POM2. 模板放入项目3.代码

Python打包成exe常用的四种方法小结

《Python打包成exe常用的四种方法小结》本文主要介绍了Python打包成exe常用的四种方法,包括PyInstaller、cx_Freeze、Py2exe、Nuitka,文中通过示例代码介绍的非... 目录一.PyInstaller11.安装:2. PyInstaller常用参数下面是pyinstal

利用Python操作Word文档页码的实际应用

《利用Python操作Word文档页码的实际应用》在撰写长篇文档时,经常需要将文档分成多个节,每个节都需要单独的页码,下面:本文主要介绍利用Python操作Word文档页码的相关资料,文中通过代码... 目录需求:文档详情:要求:该程序的功能是:总结需求:一次性处理24个文档的页码。文档详情:1、每个

Python 常用数据类型详解之字符串、列表、字典操作方法

《Python常用数据类型详解之字符串、列表、字典操作方法》在Python中,字符串、列表和字典是最常用的数据类型,它们在数据处理、程序设计和算法实现中扮演着重要角色,接下来通过本文给大家介绍这三种... 目录一、字符串(String)(一)创建字符串(二)字符串操作1. 字符串连接2. 字符串重复3. 字

Python内存管理机制之垃圾回收与引用计数操作全过程

《Python内存管理机制之垃圾回收与引用计数操作全过程》SQLAlchemy是Python中最流行的ORM(对象关系映射)框架之一,它提供了高效且灵活的数据库操作方式,本文将介绍如何使用SQLAlc... 目录安装核心概念连接数据库定义数据模型创建数据库表基本CRUD操作创建数据读取数据更新数据删除数据查

Go语言中json操作的实现

《Go语言中json操作的实现》本文主要介绍了Go语言中的json操作的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录 一、jsOChina编程N 与 Go 类型对应关系️ 二、基本操作:编码与解码 三、结构体标签(Struc

python语言中的常用容器(集合)示例详解

《python语言中的常用容器(集合)示例详解》Python集合是一种无序且不重复的数据容器,它可以存储任意类型的对象,包括数字、字符串、元组等,下面:本文主要介绍python语言中常用容器(集合... 目录1.核心内置容器1. 列表2. 元组3. 集合4. 冻结集合5. 字典2.collections模块

Java 字符串操作之contains 和 substring 方法最佳实践与常见问题

《Java字符串操作之contains和substring方法最佳实践与常见问题》本文给大家详细介绍Java字符串操作之contains和substring方法最佳实践与常见问题,本文结合实例... 目录一、contains 方法详解1. 方法定义与语法2. 底层实现原理3. 使用示例4. 注意事项二、su

Java Stream流与使用操作指南

《JavaStream流与使用操作指南》Stream不是数据结构,而是一种高级的数据处理工具,允许你以声明式的方式处理数据集合,类似于SQL语句操作数据库,本文给大家介绍JavaStream流与使用... 目录一、什么是stream流二、创建stream流1.单列集合创建stream流2.双列集合创建str