题目练习之二叉树那些事儿(续集)

news2024/11/25 21:38:49


♥♥♥~~~~~~欢迎光临知星小度博客空间~~~~~~♥♥♥

♥♥♥零星地变得优秀~也能拼凑出星河~♥♥♥

♥♥♥我们一起努力成为更好的自己~♥♥♥

♥♥♥如果这一篇博客对你有帮助~别忘了点赞分享哦~♥♥♥

♥♥♥如果有什么问题可以评论区留言或者私信我哦~♥♥♥



✨✨✨✨✨✨个人主页✨✨✨✨✨✨


目录

练习1:二叉树的前序遍历

题目

思路

代码

练习2:二叉树的中序遍历

​编辑

练习3:二叉树的后序遍历

练习4:二叉树遍历

题目

思路

代码


这一篇博客我们继续来看看二叉树的OJ题目练习~

练习1:二叉树的前序遍历

力扣——144二叉树的前序遍历

题目

二叉树的遍历前面我们说过有四种遍历方式,这里需要我们进行前序遍历,我们可以看到它输出结果是没有NULL的,所以为空时直接返回就好了。同时我们可以看到函数第二个参数是int* 类型的,根据他的名字returnSize我们猜测它是前序遍历到的结点个数~并且函数返回类型也是int* ,说明我们需要返回前序遍历结果的数组~

思路

知道了题目的要求,我们可以有下面的思路

首先求出二叉树的结点个数,创建一个结点个数大小的数组,前序遍历将结点保存的数据放到数组中,返回数组

代码

//重定义
typedef struct TreeNode TreeNode;

//总结点个数=1+左子树结点个数+右子树结点个数
int BinarySize(TreeNode* root)
{
    if(root == NULL)
    {
        return 0;
    }
    return 1 + BinarySize(root->left) + BinarySize(root->right);
}
void PreOrder(TreeNode* root,int* arr,int* pi)
{
    if(root == NULL)
    {
        return;
    }
    //前序遍历
    //根左右
    arr[(*pi)++] = root->val;
    PreOrder(root->left, arr, pi);
    PreOrder(root->right, arr, pi);
}
int* preorderTraversal(struct TreeNode* root, int* returnSize) {
    //求二叉树结点个数
    *returnSize = BinarySize(root);
    //申请空间
    int* arr = (int*)malloc((*returnSize) * sizeof(int));
    //前序遍历,保存数据到数组中
    int i = 0;
    //数组下标从0开始
    PreOrder(root,arr,&i);
    //返回数组
    return arr;
}

提交成功~

接下来两个题目是与这个题类似的,思路代码都是类似的~我们这里就直接给出代码~

练习2:二叉树的中序遍历

力扣——94二叉树的中序遍历

 //重定义
typedef struct TreeNode TreeNode;

//总结点个数=1+左子树结点个数+右子树结点个数
int BinarySize(TreeNode* root)
{
    if (root == NULL)
    {
        return 0;
    }
    return 1 + BinarySize(root->left) + BinarySize(root->right);
}

void InOrder(TreeNode* root, int* arr, int* pi)
{
    if (root == NULL)
    {
        return;
    }
    //中序遍历
    //左根右
    InOrder(root->left, arr, pi);
    arr[(*pi)++] = root->val;
    InOrder(root->right, arr, pi);
}

int* inorderTraversal(struct TreeNode* root, int* returnSize) {
     //求二叉树结点个数
    *returnSize = BinarySize(root);
    //申请空间
    int* arr = (int*)malloc((*returnSize) * sizeof(int));
    //中序遍历,保存数据到数组中
    int i = 0;
    //数组下标从0开始
    InOrder(root, arr, &i);
    //返回数组
    return arr;
}

练习3:二叉树的后序遍历

力扣——145二叉树的后序遍历

//重定义
typedef struct TreeNode TreeNode;

//总结点个数=1+左子树结点个数+右子树结点个数
int BinarySize(TreeNode* root)
{
    if (root == NULL)
    {
        return 0;
    }
    return 1 + BinarySize(root->left) + BinarySize(root->right);
}

void PostOrder(TreeNode* root, int* arr, int* pi)
{
    if (root == NULL)
    {
        return;
    }
    //后序遍历
    //左右根
    PostOrder(root->left, arr, pi);
    PostOrder(root->right, arr, pi);
    arr[(*pi)++] = root->val;
}

int* postorderTraversal(struct TreeNode* root, int* returnSize) {
    //求二叉树结点个数
    *returnSize = BinarySize(root);
    //申请空间
    int* arr = (int*)malloc((*returnSize) * sizeof(int));
    //后序遍历,保存数据到数组中
    int i = 0;
    //数组下标从0开始
    PostOrder(root, arr, &i);
    //返回数组
    return arr;
}

提交通过~

练习4:二叉树遍历

牛客——二叉树遍历

题目

这里我们会发现题目希望我们编写一个程序,而不是一个函数,那么这里就需要我们自己去创建二叉树,定义二叉树结点,不能使用现成的。

看看题目:题目希望我们给一个给定的字符串进行构造一个二叉树(#代表空格,同时也代表着空树),并且中序遍历二叉树,输出中序遍历二叉树的结果~

思路

首先我们需要定义二叉树结点,申请结点根据给定的字符串构造二叉树(这里我们构造二叉树采用的也是递归构造的方法,先构造根结点,再构造左右子树)最后进行中序遍历输出结果

代码

#include <stdio.h>
#include <stdlib.h>//malloc头文件

//定义二叉树结点
typedef char BTNodeDataTye;
typedef struct BinaryTreeNode
{
    BTNodeDataTye data;
    struct BinaryTreeNode* left;
    struct BinaryTreeNode* right;
}BTreeNode;

BTreeNode* BuyNode(BTNodeDataTye x)
{
    BTreeNode* newnode = (BTreeNode*)malloc(sizeof(BTreeNode));
    if(newnode == NULL)
    {
        perror("malloc fail");
        exit(1);
    }
    newnode->data = x;
    newnode->left = newnode->right = NULL;
    return newnode;
}
BTreeNode* BTreeCreate(BTNodeDataTye* arr,int* pi)
{
    //取到字符串下标为(*pi)的数据创建结点
    if(arr[*pi] == '#')
    {
        //往后面走,这里为空结点
        ++(*pi);
        return NULL;
    }
    BTreeNode* root = BuyNode(arr[*pi]);
    //字符串下标往后面走
    ++(*pi);
    //递归构造左右子树
    root->left = BTreeCreate(arr,pi);
    root->right = BTreeCreate(arr,pi);
    return root;
}

void Inorder(BTreeNode* root)
{
    if(root == NULL)
    {
        return;
    }
    Inorder(root->left);
    printf("%c ",root->data);
    Inorder(root->right);
}

int main() 
{
    //输入字符串//题目给出字符串长度不超过100
    char arr[100];
    scanf("%s",arr);
    //构造二叉树
    int i = 0;
    //i传地址,形参改变才会影响实参
    BTreeNode* root = BTreeCreate( arr, &i);
    //中序遍历
    Inorder(root);
    return 0;
}

提交通过~我们再一次体会了递归的暴力美学~

除此之外,我的博客即将同步至腾讯云开发者社区,邀请大家一同入驻:https:/cloud.tencent.com/developer/support-plan?invite_code=34m59s418000k


♥♥♥本篇博客内容结束,期待与各位优秀程序员交流,有什么问题请私信♥♥♥

♥♥♥如果这一篇博客对你有帮助~别忘了点赞分享哦~♥♥♥


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

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

相关文章

【入门篇】确定字符串是否包含唯一字符——多语言版本

题目跳转&#xff1a;确定字符串是否包含唯一字符 题目解析 这个问题要求我们判断一个字符串中的字符是否唯一&#xff08;忽略字母的大小写&#xff09;&#xff0c;并输出相应的结果。如果字符串中所有的字符都是唯一的&#xff0c;输出 YES&#xff1b;否则&#xff0c;输…

ConcurrentModificationException:检测到并发修改完美解决方法

&#x1f6a6; ConcurrentModificationException&#xff1a;检测到并发修改完美解决方法 &#x1f4a1; &#x1f6a6; ConcurrentModificationException&#xff1a;检测到并发修改完美解决方法 &#x1f4a1;摘要1. 什么是ConcurrentModificationException&#xff1f;&…

并查集 How many tables(hdu 1213) How many answers are wrong(hdu 3038)

目录 前言 并查集 并查集的初始化 并查集的合并 并查集合并的优化&#xff0c;路径压缩 How many tables(hdu 1213) 问题描述 输入 输出 问题分析 代码 带权并查集 How many answers are wrong(hdu 3038) 问题描述 输入 输出 问题分析 代码 前言 感觉并查集总共有两个应…

JavaScript day01 笔记

一、引入方式 JavaScript 程序不能独立运行&#xff0c;它需要被嵌入 HTML 中&#xff0c;然后浏览器才能执行 JavaScript 代码。通过 script 标签将 JavaScript 代码引入到 HTML 中 1️⃣内部 通过 script 标签包裹 JavaScript 代码&#xff08;一般就写在</script>的…

Notepad++ 最新官网中文版在线下载 附文本编辑器安装与基础使用教程

Notepad &#xff08;记事本&#xff09;是一个简单的文本编辑器&#xff0c;预装在所有版本的 Microsoft Windows 操作系统中。它的主要功能是创建、编辑和存储纯文本文件&#xff0c;通常以 .txt 格式保存。Notepad 的设计旨在提供一个轻量级的文本处理工具&#xff0c;适合快…

使用C语言进行信号处理:从理论到实践的全面指南

1. 引言 在现代操作系统中&#xff0c;信号是一种进程间通信机制&#xff0c;它允许操作系统或其他进程向一个进程发送消息。信号可以用来通知进程发生了一些重要事件&#xff0c;如用户请求终止进程、硬件异常、定时器超时等。掌握信号处理技术对于开发健壮、高效的系统程序至…

大数据入门-什么是HBase

目录 一、概念 二、架构 1.Client 2.Zookeeper 3.HMaster 4.HRegionServer 三、特性 1.数据存储庞大 2.支持随机读写 3.轻松融入生态 4.数据强一致性 5.性能足够高效 四、适用场景 五、其他事宜 1.权益备注 2.支持博主 大数据入门系列文章 这里简单介绍的HBas…

【笔记】自动驾驶预测与决策规划_Part6_不确定性感知的决策过程

文章目录 0. 前言1. 部分观测的马尔可夫决策过程1.1 POMDP的思想以及与MDP的联系1.1.1 MDP的过程回顾1.1.2 POMDP定义1.1.3 与MDP的联系及区别POMDP 视角MDP 视角决策次数对最优解的影响 1.2 POMDP的3种常规解法1.2.1 连续状态的“Belief MDP”方法1. 信念状态的定义2. Belief …

Vue2中使用firefox的pdfjs进行文件文件流预览

文章目录 1.使用场景2. 使用方式1. npm 包下载,[点击查看](https://www.npmjs.com/package/pdfjs-dist)2. 官网下载1. 放到public文件夹下面2. 官网下载地址[点我,进入官网](https://github.com/mozilla/pdf.js/tags?afterv3.3.122) 3. 代码演示4. 图片预览5. 如果遇到跨域或者…

MFC图形函数学习06——画椭圆弧线函数

绘制椭圆弧线函数是MFC基本绘图函数&#xff0c;这个函数需要的参数比较多&#xff0c;共四对坐标点。前两对坐标点确定椭圆的位置与大小&#xff0c;后两对坐标确定椭圆弧线的起点与终点。 一、绘制椭圆弧线函数 原型&#xff1a;BOOL Arc(int x1,int y1,int x2,int y2…

新版 idea 编写 idea 插件时,启动出现 ClassNotFound

IntelliJ IDEA 2024.1.6 (Ultimate Edition) Build #IU-241.19072.14, built on August 8, 2024 Licensed to Sophia Tout Subscription is active until June 29, 2025. For educational use only. Runtime version: 17.0.111-b1207.30 amd64 Kotlin: 241.19072.14-IJ 新版本…

信息安全工程师(83)Windows操作系统安全分析与防护

一、Windows操作系统安全分析 系统漏洞&#xff1a; Windows操作系统由于其复杂性和广泛使用&#xff0c;可能存在一些已知或未知的漏洞。这些漏洞可能会被黑客利用&#xff0c;进行恶意攻击。微软会定期发布系统更新和补丁&#xff0c;以修复这些漏洞&#xff0c;提高系统的安…

【嵌入式开发——ARM】1ARM架构

嵌入式领域&#xff0c;使用ARM架构的芯片公司可不占少数吧&#xff0c;intel的x86架构主要占据PC、服务器市场&#xff0c;ARM架构主要占据移动市场。x86架构和ARM架构不同的主要原因&#xff0c;是背后使用的计算机指令集不同。计算机有自己的语言系统&#xff08;汇编&#…

31-自定义地图:分层地图

利用自定义地图中的级别&#xff0c;可以让多个人同时在一张地图上工作。它还允许您在仿真过程中使用Python API在地图上加载和卸载层&#xff0c;就像分层的CARLA地图一样(layered CARLA maps)。 本指南将解释如何添加新级别&#xff0c;如何向级别添加资产&#xff0c;以…

操作系统-磁盘

文章目录 磁盘的结构一、磁盘的物理结构二、磁盘的逻辑结构 磁盘的调度算法磁盘时间算法先来先服务&#xff08;FCFS - First-Come, First-Served&#xff09;最短寻道时间优先&#xff08;SSTF - Shortest Seek Time First&#xff09;扫描算法&#xff08;SCAN&#xff0c;也…

【Linux】【信号操作】汇总整理

信号&#xff08;Signals&#xff09;是操作系统中用于通知进程发生特定事件的一种机制。信号可以由软件或硬件触发&#xff0c;并且可以被进程捕获和处理。以下是信号的相关概念、常见信号列表、信号处理以及相关API的汇总整理。 信号概述 信号是操作系统向进程发出的通知&am…

必备的计算机软件专业资料汇总,包括:计算机专业实习报告,计算机毕业设计成品(含源码和论文1900套)

大学期间必备的计算机软件专业资料汇总&#xff0c;包括&#xff1a;计算机专业实习报告&#xff08;58篇&#xff09;、计算机毕业设计成品&#xff08;含源码和论文&#xff0c;1900多套&#xff0c;包括C语言/PHP/VB/java/JSP/Andorid/Python/微信小程序等&#xff09;、HTM…

业务模块部署

一、部署前端 1.1 window部署 下载业务模块前端包。 &#xff08;此包为耐威迪公司发布&#xff0c;请联系耐威迪客服或售后获得&#xff09; 包名为&#xff1a;业务-xxxx-business &#xff08;注&#xff1a;xxxx为发布版本号&#xff09; 此文件部署位置为&#xff1a;……

使用kalibr_calibration标定相机(realsense)和imu(h7min)

vslam-evaluation/VINS/Installation documentation/4.IMU和相机联合标定kalibr_calibration.md at master DroidAITech/vslam-evaluation GitHub 目录 1.kalibr安装 1.1安装依赖项 1.2创建工作空间 1.3下载kalibr并编译 1.4设置环境变量 2.准备标定板 3.配置驱动和打…

Java | Leetcode Java题解之第551题学生出勤记录I

题目&#xff1a; 题解&#xff1a; class Solution {public boolean checkRecord(String s) {int absents 0, lates 0;int n s.length();for (int i 0; i < n; i) {char c s.charAt(i);if (c A) {absents;if (absents > 2) {return false;}}if (c L) {lates;if …