数据结构------树(Java语言描述)

一、树的基本概念

树是一种非线性的数据结构,它由节点组成,有一个特定的节点称为根节点,其余节点可以分为多个互不相交的子树。

树中的节点具有以下特点:

1.每个节点有零个或多个子节点。

2.除了根节点外,每个节点有且仅有一个父节点。

3.没有父节点的节点就是根节点,没有子节点的节点称为叶子节点。

二、代码示例

下面是二叉树的代码示例(Java语言)

package dataStructure.tree;//二叉树的节点类
public class TreeNode {//用来保存节点的数据int data;//用来保存该节点的左右子节点TreeNode left;TreeNode right;//使用构造方法来限制节点对象必须有值public TreeNode(int data){this.data = data;}
}
package dataStructure.tree;//二叉树类
public class BinaryTree {//二叉树的根节点private TreeNode root;//往二叉树中添加数据public void add(int e) {//先创建节点对象,然后再判断他要放到什么位置TreeNode node = new TreeNode(e);if (root == null) {//如果当前树是空的,则把该节点作为根节点root = node;} else {add(root, node);}}private void add(TreeNode t, TreeNode n) {if (n.data < t.data) {if (t.left == null) {t.left = n;return;}add(t.left, n);} else {if (t.right == null) {t.right = n;return;}add(t.right, n);}}//前序遍历public void preOrder() {preOrder(root);}private void preOrder(TreeNode node) {if (node == null) {return;}System.out.println(node.data);preOrder(node.left);preOrder(node.right);}//中序遍历public void middleOrder() {middleOrder(root);}private void middleOrder(TreeNode node) {if (node == null) {return;}middleOrder(node.left);System.out.println(node.data);middleOrder(node.right);}//后序遍历public void rearOrder() {rearOrder(root);}private void rearOrder(TreeNode node) {if (node == null) {return;}rearOrder(node.left);rearOrder(node.right);System.out.println(node.data);}public static void main(String[] args) {BinaryTree bt = new BinaryTree();bt.add(10);bt.add(5);bt.add(15);bt.add(3);bt.add(8);bt.add(2);bt.add(4);bt.add(7);bt.add(9);bt.add(12);bt.add(18);bt.add(11);bt.add(13);bt.add(16);bt.add(20);bt.preOrder();System.out.println("-----------------------------------------------");bt.middleOrder();System.out.println("-----------------------------------------------");bt.rearOrder();}
}

 

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

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

相关文章

查看浏览器的请求头

爬虫时用到了请求头&#xff0c;虽然可以用网上公开的&#xff0c;但是还是想了解一下本机浏览器的。以 Edge 为例&#xff0c;其余浏览器通用。 打开浏览器任一网页&#xff0c;按F12打开DevTools&#xff1b;或鼠标右键&#xff0c;选择“检查”。首次打开界面应该显示在网页…

如何在Python中进行数学建模?

数学建模是数据科学中使用的强大工具&#xff0c;通过数学方程和算法来表示真实世界的系统和现象。Python拥有丰富的库生态系统&#xff0c;为开发和实现数学模型提供了一个很好的平台。本文将指导您完成Python中的数学建模过程&#xff0c;重点关注数据科学中的应用。 数学建…

前后端分离,解决vue+axios跨域和proxyTable不生效等问题

看到我这篇文章前可能你以前看过很多类似的文章。至少我是这样的&#xff0c;因为一直没有很好的解决问题。 正文 当我们通过webstorm等IDE开发工具启动项目的时候&#xff0c;通过命令控制台可以观察到启动项目的命令 如下&#xff1a; webpack-dev-server --inline --prog…

ES6 、ESNext 规范、编译工具babel

ES6 、ESNext 规范、编译工具简介 ES6ES&#xff08;ECMAScript&#xff09; vs JS常量进一步探讨 obj对象的扩展面试&#xff1a;使对象属性也不能更改——Object.freeze(obj) 解构deconstruction变量的解构赋值&#xff1a;数组解构赋值&#xff1a;对象解构赋值&#xff1a;…

阿里数字人工作 Emote Portrait Alive (EMO):基于 Diffusion 直接生成视频的数字人方案

TL;DR 2024 年 ECCV 阿里智能计算研究所的数字人工作&#xff0c;基于 diffusion 方法来直接的从音频到视频合成数字人&#xff0c;避免了中间的三维模型或面部 landmark 的需求&#xff0c;效果很好。 Paper name EMO: Emote Portrait Alive - Generating Expressive Portra…

Python枚举类详解:用enum模块高效管理常量数据

《Python OpenCV从菜鸟到高手》带你进入图像处理与计算机视觉的大门! 在编程中,常量的管理是一个关键环节,合理的管理常量可以提高代码的可读性和可维护性。Python的enum模块提供了一种有效的方式来组织常量数据,通过枚举类(Enum)将相关的常量值集合在一起,使代码更具结…

candence: 如何快速设置SUBCLASS 的颜色

如何快速设置SUBCLASS 的颜色 一、一般操作 正常情况下修改SUBCLASS&#xff0c;需要如下步骤进行设置&#xff1a; 二、快速操作 右键&#xff0c;选择一个颜色即可

多目标优化算法:多目标海星优化算法(MOSFOA)求解ZDT1、ZDT2、ZDT3、ZDT4、ZDT6,提供完整MATLAB代码

一、海星优化算法 海星优化算法&#xff08;Starfish Optimization Algorithm &#xff0c;SFOA&#xff09;是2024年提出的一种元启发式算法&#xff0c;该算法模拟了海星的行为&#xff0c;包括探索、捕食和再生。 算法灵感&#xff1a; SFOA的灵感来源于海星的捕食行为&…

实时质检-静音检测分析流程(运维人员使用)

前言 用户在实时质检时&#xff0c;开启了主叫或被叫静音检测功能&#xff0c;但是听录音时&#xff0c;主叫或被叫明明没有任何声音&#xff0c;但是通话没有被挂断。 说明主叫或被叫的静音阈值太低&#xff0c;导致系统没有把很小的声音认定为静音&#xff1b;或者检测非静音…

Android Gradle 插件和 Android Studio 兼容性

Android Gradle 插件和 Android Studio 兼容性 Android Studio 版本所需的 AGP 版本Ladybug 2024.2.13.2-8.7Ladybug 2024.2.13.2-8.7Koala 2024.1.12024.2.1Jellyfish 2023.3.12024.2.1Iguana 2023.2.13.2-8.3Hedgehog 2023.1.13.2-8.2Giraffe 2022.3.13.2-8.1Flamingo 2022.…

python中如何计算布尔值

布尔值是 Python 中的基本数据类型&#xff0c;只有两个值&#xff1a; True 表示“真”。注意首字母都是大写False 表示“假”。 那么问题来了&#xff0c;什么样的值是True&#xff0c;什么样的值是False呢&#xff1f; 值为True的情况有无数种&#xff0c;但是为False的就…

阿里云cdn配置记录和nodejs手动安装

cdn 登录阿里云 域名解析权限 开启cdn&#xff0c;接引导流程&#xff0c; 源可以设置 域名或者ip等 配置好域名解析 上传https证书 图片不显示&#xff0c;后端开发需要配置 回源配置的回源协议 &#xff0c;配置跟随客服端【如果浏览器多次重定向错误&#xff0c;客服或者改…

了解Redis(第一篇)

目录 Redis基础 什么事Redis Redis为什么这么快 除了 Redis&#xff0c;你还知道其他分布式缓存方案吗? 说-下 Redis 和 Memcached 的区别和共同点 为什么要用Redis? 什么是 Redis Module?有什么用? Redis基础 什么事Redis Redis &#xff08;REmote DIctionary S…

D77【 python 接口自动化学习】- python基础之HTTP

day77 postman接口请求 学习日期&#xff1a;20241123 学习目标&#xff1a;http 定义及实战&#xfe63;&#xfe63;postman接口请求 学习笔记&#xff1a; get请求 post请求 总结 get请求用于查询数据post请求用于添加数据

Element-Ui组件(icon组件)

一、前言 本篇文章主要是对官网的Icon组件进行总结归纳Icon 图标 | Element Plus 在现代Web应用开发中&#xff0c;图标是用户界面设计中不可或缺的一部分。它们不仅提升了用户体验&#xff0c;还使得信息的传达更加直观和高效。本文主要对Element Plus 官方提供的Icon组件进行…

SpringMVC——简介及入门

SpringMVC简介 看到SpringMVC这个名字&#xff0c;我们会发现其中包含Spring&#xff0c;那么SpringMVC和Spring之间有怎样的关系呢&#xff1f; SpringMVC隶属于Spring&#xff0c;是Spring技术中的一部分。 那么SpringMVC是用来做什么的呢&#xff1f; 回想web阶段&#x…

flink1.16+连接Elasticsearch7官方例子报错解决方案

flink输出至es&#xff0c;连接es7时使用的sink类是Elasticsearch7SinkBuilder&#xff0c;与es6链接方式不同&#xff0c;官网地址&#xff1a;fink连接es官方地址。 flink连接es7官方示例 依赖jar&#xff1a; <dependency><groupId>org.apache.flink</gro…

力扣--LRC 142.训练计划IV

题目 给定两个以 有序链表 形式记录的训练计划 l1、l2&#xff0c;分别记录了两套核心肌群训练项目编号&#xff0c;请合并这两个训练计划&#xff0c;按训练项目编号 升序 记录于链表并返回。 注意&#xff1a;新链表是通过拼接给定的两个链表的所有节点组成的。 示例 1&am…

应急响应靶机——linux2

载入虚拟机&#xff0c;打开虚拟机&#xff1a; 居然是没有图形化界面的那种linux&#xff0c;账户密码&#xff1a;root/Inch957821.&#xff08;注意是大写的i还有英文字符的.&#xff09; 查看虚拟机IP&#xff0c;192.168.230.10是NAT模式下自动分配的 看起来不是特别舒服&…

《Python 股票交易分析:开启智能投资新时代》(二)

Python 进行股票交易分析的优势 简洁易读&#xff1a;Python 的语法简洁明了&#xff0c;即使是编程新手也能较快上手&#xff0c;降低了股票交易分析的门槛。 Python 的简洁易读是其在股票交易分析中受欢迎的重要原因之一。Python 的语法简洁明了&#xff0c;与其他编程语言相…