十天学完基础数据结构-第六天(树(Tree))

在这里插入图片描述

树的基本概念

是一种层次性的数据结构,它由节点组成,这些节点按照层次关系相互连接。树具有以下基本概念:

  • 根节点:树的顶部节点,没有父节点。

  • 子节点:树中每个节点可以有零个或多个子节点。

  • 叶节点:没有子节点的节点称为叶节点。

  • 父节点:每个节点都可以有一个父节点,除了根节点。

  • 深度:节点所在的层次称为深度。根节点的深度为0,其子节点深度为1,以此类推。

二叉树和二叉搜索树(BST)的定义

二叉树是一种特殊的树,其中每个节点最多有两个子节点:左子节点和右子节点。

**二叉搜索树(BST)**是一种二叉树,其中每个节点都遵循以下规则:

  • 左子树中的所有节点的值小于当前节点的值。

  • 右子树中的所有节点的值大于当前节点的值。

这种有序性使得二叉搜索树非常适合搜索和排序操作。

树的遍历方法

遍历树意味着按照一定顺序访问树中的节点。树的三种常见遍历方法如下:

  • 前序遍历:首先访问根节点,然后按照左子树、右子树的顺序遍历。

  • 中序遍历:首先遍历左子树,然后访问根节点,最后遍历右子树。中序遍历可以用于对BST进行排序。

  • 后序遍历:首先遍历左子树,然后遍历右子树,最后访问根节点。

下面是一个简单的C++示例,创建二叉树和进行中序遍历:

#include <iostream>// 二叉树节点定义
struct TreeNode {int data;           // 节点数据TreeNode* left;     // 左子节点TreeNode* right;    // 右子节点
};// 中序遍历函数
void inOrderTraversal(TreeNode* root) {if (root != nullptr) {inOrderTraversal(root->left);std::cout << root->data << " ";inOrderTraversal(root->right);}
}int main() {// 创建二叉树TreeNode* root = new TreeNode{1, nullptr, nullptr};root->left = new TreeNode{2, nullptr, nullptr};root->right = new TreeNode{3, nullptr, nullptr};// 中序遍历inOrderTraversal(root);return 0;
}

运行结果:
在这里插入图片描述

练习题:

  1. 二叉树和二叉搜索树有何不同?什么情况下你会选择使用二叉搜索树?

  2. 解释中序遍历的概念。为什么中序遍历在二叉搜索树中非常有用?

  3. 描述一种情况,其中树结构比线性数据结构(如数组或链表)更适合存储和组织数据。

  4. 请编写一个C++程序,创建一个简单的二叉树,并执行中序遍历,以输出节点的值。

二叉树和二叉搜索树有何不同?什么情况下你会选择使用二叉搜索树?

  • 不同之处:主要区别在于有序性。二叉树是一种树形结构,每个节点最多有两个子节点。而二叉搜索树(BST)是一种特殊的二叉树,具有有序性。在BST中,左子树中的所有节点的值小于当前节点的值,右子树中的所有节点的值大于当前节点的值。

  • 选择BST的情况:你会选择使用BST的情况包括需要高效的搜索和排序操作时。BST的有序性使得搜索操作非常快速,平均时间复杂度为O(log n),其中n是树中节点的数量。此外,BST还可以用于实现字典、数据库索引等需要快速查找和插入的应用。

解释中序遍历的概念。为什么中序遍历在二叉搜索树中非常有用?

  • 中序遍历是一种树的遍历方式,其基本概念是按照左子树、根节点、右子树的顺序遍历树中的节点。在中序遍历中,首先遍历左子树中的所有节点,然后访问根节点,最后遍历右子树中的所有节点。

  • 中序遍历在BST中的重要性:在BST中,中序遍历可以按照升序顺序访问树中的节点。这意味着通过中序遍历可以得到有序的节点序列。因此,中序遍历在BST中非常有用,可以用于实现对树的排序操作,也可以用于搜索操作,因为在有序序列中可以快速找到目标值。

描述一种情况,其中树结构比线性数据结构(如数组或链表)更适合存储和组织数据。

  • 情况示例:组织文件系统。文件系统通常采用树形结构来组织文件和文件夹。每个文件夹可以包含文件和其他文件夹,这形成了一个树状结构,其中根节点代表顶级目录,叶节点代表文件。这种树形结构使得文件系统可以轻松实现文件的组织、搜索和访问。

注意:树结构在这种情况下更适合,因为它能够清晰地表示文件之间的层次关系和组织结构,而线性数据结构(如数组)通常不足以表示这种复杂性。

请编写一个C++程序,创建一个简单的二叉树,并执行中序遍历,以输出节点的值。

创建一个二叉树并进行中序遍历:

#include <iostream>// 二叉树节点定义
struct TreeNode {int data;           // 节点数据TreeNode* left;     // 左子节点TreeNode* right;    // 右子节点
};// 中序遍历函数
void inOrderTraversal(TreeNode* root) {if (root != nullptr) {inOrderTraversal(root->left);std::cout << root->data << " ";inOrderTraversal(root->right);}
}int main() {// 创建二叉树TreeNode* root = new TreeNode{4, nullptr, nullptr};root->left = new TreeNode{2, nullptr, nullptr};root->right = new TreeNode{6, nullptr, nullptr};root->left->left = new TreeNode{1, nullptr, nullptr};root->left->right = new TreeNode{3, nullptr, nullptr};root->right->left = new TreeNode{5, nullptr, nullptr};root->right->right = new TreeNode{7, nullptr, nullptr};// 中序遍历inOrderTraversal(root);return 0;
}

运行结果:在这里插入图片描述

这个程序创建了一个简单的二叉树,并使用中序遍历打印节点的值。

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

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

相关文章

第46节——redux中使用不可变数据+封装immer中间件——了解

一、为什么redux中要使用不可变数据 Redux 要求使用不可变数据&#xff0c;是因为它遵循了函数式编程的原则。在函数式编程中&#xff0c;数据不可变是一项重要的原则&#xff0c;这有助于避免状态更改产生的不可预知的副作用。 在 Redux 中&#xff0c;每当 action 被分发&a…

C#,数值计算——Sobol拟随机序列的计算方法与源程序

1 文本格式 using System; using System.Collections.Generic; namespace Legalsoft.Truffer { /// <summary> /// Sobol quasi-random sequence /// </summary> public class Sobol { public Sobol() { } public static void sobseq(int n,…

基于Android的英语学习软件/英语学习系统

摘 要 随着信息技术和网络技术的飞速发展&#xff0c;人类已进入全新信息化时代&#xff0c;传统管理技术已无法高效&#xff0c;便捷地管理信息。为了迎合时代需求&#xff0c;优化管理效率&#xff0c;各种各样的APP应运而生&#xff0c;各行各业相继进入信息管理时代&#x…

【微信小程序开发】一文学会使用CSS控制样式布局与美化

引言 在微信小程序开发中&#xff0c;CSS样式布局和美化是非常重要的一部分&#xff0c;它能够为小程序增添美感&#xff0c;提升用户体验。本文将介绍如何学习使用CSS进行样式布局和美化&#xff0c;同时给出代码示例&#xff0c;帮助开发者更好地掌握这一技巧。 一、CSS样式布…

探索一种C++中构造对象的方式

序 本文展示一种构造对象的方式&#xff0c;用户无需显式调用构造函数。 对于有参数的构造函数的类&#xff0c;该实现在构造改对象时传递默认值来构造。当然用户也可以指定(绑定)某个参数的值。 实现思路参考boost-ext/di的实现。 来看下例子&#xff1a; struct Member{int…

milvus 结合Thowee 文本转向量 ,新建表,存储,搜索,删除

1.向量数据库科普 【上集】向量数据库技术鉴赏 【下集】向量数据库技术鉴赏 milvus连接 from pymilvus import connections, FieldSchema, CollectionSchema, DataType, Collection, utility connections.connect(host124.****, port19530)2.milvus Thowee 文本转向量 使用 …

Ae 效果:CC Page Turn

扭曲/CC Page Turn Distort/CC Page Turn CC Page Turn &#xff08;CC 翻页&#xff09;主要用于模拟书页翻动的效果。通过使用该效果&#xff0c;用户可以创建出像书页或杂志页面翻动的视觉效果&#xff0c;增强影片的交互性和视觉吸引力。 ◆ ◆ ◆ 效果属性说明 Contro…

opencv入门教程

opencv入门教程 图像的读取&#xff0c;显示&#xff0c;与写入摄像头保存视频读取视频画画鼠标操作event 参数说明flags 参数说明 轨迹栏图像基本操作图像处理HSV颜色空间几何变换放大缩小平移旋转仿射变换透视变换简单阈值自适应阈值Otsu的二值化 2D卷积&#xff08;图像过滤…

Jmeter-Beanshell取样器中引入自制的java脚本(jar java class)

1、内置变量&#xff1a;log&#xff1a;写入信息到jmeter.log&#xff0c;使用方法&#xff1a; log.info(“hello,world”)&#xff0c;也可以在jmetergui上看到打印的信息。 2、设置Jmeter变量的值&#xff0c;将定义的变量或提取的变量做修改后再进行传参 Vars:操作jmete…

创建一个新的IDEA插件项目

启动IntelliJ IDEA并按照以下步骤创建新的插件项目&#xff1a; 打开IntelliJ IDEA并单击“Create New Project”&#xff08;创建新项目&#xff09;。 在左侧菜单栏中选择“IntelliJ Platform Plugin”&#xff08;IntelliJ平台插件&#xff09;。 在右侧窗格中&#xff0c…

Android base64编码、图片转换

1 将base64编码转化成图片 &#xff08;1&#xff09;类似base64流的图片解析并展示&#xff1a; data:image/jpeg;base64,/9j/4AAQSkZJRgABAQEASABIAAD/2wBDAAUDBAQEAwUEBAQFBQUGBwwIBwcH Bw8LCwkMEQ8SEhEPERETFhwXExQaFRERGCEYGh0dHx8fExciJCIeJBweHx7/2wBDAQUFBQcGBw4ICA4…

Python:操作SQLite数据库简单示例

本文用最简单的示例演示python标准库提供的SQLite数据库进行新增、查询数据的过程。 代码文件app.py # -*- coding: UTF-8 -*- from flask import Flask import sqlite3app Flask(__name__)app.route(/) def hello_world():return Hello World!#创建数据库 app.route(/creat…

SpringMVC的数据绑定

一、前言 SpringMVC的数据绑定是指将HTTP请求参数绑定到Java对象上。这样可以方便地从请求中获取数据并将其传递给业务逻辑。在SpringMVC中&#xff0c;可以使用RequestParam和ModelAttribute等注解来实现数据绑定。 二、使用RequestParam注解 RequestParam注解用于将请求参…

ros编译报错-- Could NOT find ros_ethercat_eml (missing: ros_ethercat_eml_DIR)

– Could NOT find ros_ethercat_eml (missing: ros_ethercat_eml_DIR) – Could not find the required component ‘ros_ethercat_eml’. The following CMake error indicates that you either need to install the package with the same name or change your environment …

linux入门---信号的保存和捕捉

目录标题 信号的一些概念信号的保存pending表block表handler表 信号的捕捉内核态和用户态信号的捕捉 信号的一些概念 1.进程会收到各种各样的信号&#xff0c;那么程序对该信号进行实际处理的动作叫做信号的递达。 2.我们之前说过当进程收到信号的时候可能并不会立即处理这个信…

虚拟机通过nat模式端口映射实现内网穿透

虚拟机通过nat模式端口映射实现内网穿透 1.网络状态 windows虚拟主机的IP为局域网的私有IP192.168.1.7linux的虚拟主机IP为nat的172.36.4.1062.linux修改nat模式的端口映射 3.windows宿主机防火墙添加规则,&#xff08;或者直接关闭公共网络防火墙&#xff0c;不安全&#xf…

Appleid苹果账号自动解锁改密(自动解锁二验改密码)

目前该项目能实现以下功能&#xff1a; 多用户使用&#xff0c;权限控制多账号管理账号分享页&#xff0c;支持设置密码、有效期、自定义HTML内容自动解锁与关闭二步验证自动/定时修改密码自动删除Apple ID中的设备代理池与Selenium集群&#xff0c;提高解锁成功率允许手动触发…

LogisticRegression 与 LogisticRegressionCV 的区别

LogisticRegression 和 LogisticRegressionCV 是 scikit-learn 库中用于逻辑回归的两个类&#xff0c;它们之间的区别如下。 1、LogisticRegression LogisticRegression 是用于二分类或多分类问题的逻辑回归模型。可以使用不同的优化算法&#xff08;如拟牛顿法、坐标下降法&…

C++ 结构化、联合、枚举、

结构化 #include <iostream> int main() { // 结构1struct contact {char phone[20];char email[20];}; // 这里可以添加变量 也可以在后面自行创建// 结构2 注意嵌套struct person {char name[20];int gender;double h;double w;struct contact c;};// 创建 并 赋值…

国庆作业5

QT实现TCP服务器客户端的搭建 服务器代码&#xff1a; #include "widget.h" #include "ui_widget.h"Widget::Widget(QWidget *parent): QWidget(parent), ui(new Ui::Widget) {ui->setupUi(this);server new QTcpServer(this);connect(server,&Q…