【数据结构二叉树OJ系列】1、二叉树的前序遍历

news2024/9/27 9:27:16

目录

题述(力扣难度:中等):

思路:

 正确代码如下:

典型错误:


题述(力扣难度:中等)

给你二叉树的根节点 root返回它节点值的 前序 遍历

示例1:

 示例2:

输入:root = 【】

输出:【】

示例3:

输入:root = 【1】

输出:【1】

题中已给如下,让你完善preorderTraversal函数

struct TreeNode
{
    int val;
    struct TreeNode* left;
    struct TreeNode* right;
};

/*Note:The returned array must be malloced,assume caller calls free()*/
int* preorderTraversal(struct TreeNode* root, int* returnSize) 

提示:

  • 树中的节点数目在【0,100】内
  • -100 <= node.val <= 100

思路:

本题不是简单的前序遍历,因其要求前序遍历的节点放在动态开辟的数组中

问题一:那数组开辟多大?需要一个求树节点个数的函数TreeSize,因在我的另一个博客二叉树的实现讲过思路,这里就不赘述了。然后前序遍历放入数组即可,这明显是个递归

问题二:递归不能在preorderTraversal中递归,因为它其中有计算二叉树大小和动态开辟数组,而不用每次递归都算,故干脆写个子函数_preorderTraversal(前面加_一般表示某个函数的子函数的意思),然后在_preorderTraversal函数中每次递归把前序遍历的值从数组第i个下标开始放入数组中。

 正确代码如下:

struct TreeNode
{
	int val;
	struct TreeNode* left;
	struct TreeNode* right;
};

int TreeSize(struct TreeNode* root)
{
	if (root == NULL)
	{
		return 0;
	}

	return 1 + TreeSize(root->left) + TreeSize(root->right);
}

void _preorderTraversal(struct TreeNode* root, int* array, int* pi)
{
	if (root == NULL)
	{
		return;
	}

	array[(*pi)++] = root->val;
	_preorderTraversal(root->left, array, pi);
	_preorderTraversal(root->right, array, pi);
}
/*Note:The returned array must be malloced,assume caller calls free()*/
int* preorderTraversal(struct TreeNode* root, int* returnSize)
{
	int size = TreeSize(root);
	int* array = (int*)malloc(sizeof(int) * size);
	int i = 0;//表示从数组中第i个下标开始放入数组中
	_preorderTraversal(root, array, &i);

	*returnSize = size;
	return array;
}

典型错误:

i不用指针传地址调用可以吗?不行!

下面代码就是错误的,因没有用地址调用。 



void _preorderTraversal(struct TreeNode* root, int* array, int i)
{
	if (root == NULL)
	{
		return;
	}

	array[i] = root->val;
	++i;
	_preorderTraversal(root->left, array, i);
	_preorderTraversal(root->right, array, i);
}
/*Note:The returned array must be malloced,assume caller calls free()*/
int* preorderTraversal(struct TreeNode* root, int* returnSize)
{
	int size = TreeSize(root);
	int* array = (int*)malloc(sizeof(int) * size);
	int i = 0;//表示从数组中第i个下标开始放入数组中
	_preorderTraversal(root, array, i);

	*returnSize = size;
	return array;
}

 

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

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

相关文章

HappyDet安装使用教程

作者&#xff1a;堆堆星 导读 一般的深度学习流程包括数据采集&#xff0c;数据标注&#xff0c;训练&#xff0c;调参&#xff0c;测试&#xff0c;部署。流程繁琐&#xff0c;且周期极长。HappyDet以深度学习中目标检测算法为核心&#xff0c;开发了一套本地的全流程目标检测…

Blender基础入门(0):下载和资源

文章目录 我个人的Blender专栏前言相关资料Blender和C4D如何选择视频资源BlenderBlender官网下载基础设置常用快捷键介绍空格键&#xff1a;跳出选择框ShiftA&#xff1a;跳出添加框选中物体按F9:显示物体属性 Blender能做到什么总结 我个人的Blender专栏 Blender简单教学 前…

9.30UEC++ 注册执行指令

1. 只能在GameMode或者PlayController中使用 创建一个函数,在函数前定义宏&#xff0c;专门为下一行函数使用&#xff08;指令框宏&#xff09; 2.定义函数 书写功能逻辑&#xff1a;打印日志 3.操作演示: 编译之后&#xff0c;运行客户端&#xff0c;按下~键&#xff0c;输…

网络编程—Socket套接字详解

目录 一、网络编程 1.1、为什么需要网络编程&#xff1f; 1.2、什么是网络编程 1.3、发送端和接收端 ​编辑1.4、请求和响应 ​编辑1.5、客户端和服务端 二、Socket套接字 2.1、概念 2.2、分类 2.2.1、流套接字 2.2.2、数据报套接字 2.2.3、原始套接字 2.3、…

面向对象编程主线五

面向对象编程 五、第五阶段–多态性 5.1、理解多态性 理解多态性&#xff1a;可以理解为一个事物的多种形态&#xff1b; 何为多态性&#xff1a; 对象的多态性&#xff1a;父类的引用指向子类的对象&#xff08;或子类的对象赋给父类的引用&#xff09; 多态的使用&#x…

味尚食品 味尚拉面半干面是一种非常经典的中式面食

尊敬的客户&#xff0c;您好&#xff01;感谢您对我们电商平台的关注&#xff0c;我们很高兴为您介绍我们平台上的一款热销产品——味尚拉面半干面。 味尚拉面半干面是一种非常经典的中式面食&#xff0c;其主要特点体现在面条的口感和味道方面&#xff0c;让人感觉仿佛在享受正…

infinigen安装教程

至于infinigen是什么&#xff0c;网上很多&#xff0c;这篇文章主要是我安装的记录 官网&#xff1a;https://infinigen.org/ github&#xff1a;https://github.com/princeton-vl/infinigen 安装 首先要配置wsl环境&#xff0c;如何配置wsl&#xff0c;可以关注公众号“科…

依次判断数组中的各元素是否以指定后缀作为结尾numpy.char.endswith()

【小白从小学Python、C、Java】 【计算机等考500强证书考研】 【Python-数据分析】 依次判断数组中的各元素 是否以指定后缀作为结尾 numpy.char.endswith() [太阳]选择题 下列代码最后输出的结果是&#xff1f; import numpy as np s np.array([teacher, student]) print(&…

Spring Boot 中的定时任务是什么, 如何使用

Spring Boot 中的定时任务是什么, 如何使用 Spring Boot 是一个非常流行的 Java Web 开发框架&#xff0c;它可以帮助开发者快速搭建一个 Web 应用程序。为了能够更好地管理后台任务&#xff0c;Spring Boot 提供了一种方便的方式来调度定时任务。这个功能被称为 Spring Boot …

Python应用实例(一)外星人入侵(四)

外星人入侵&#xff08;四&#xff09; 1.前文总结回顾1.1 alien_invasion.py1.2 settings.py1.3 ship.py 2.射击2.1 添加子弹设置2.2 创建Bullet类2.3 将子弹存储到编组中2.4 开火2.5 删除消失的子弹2.6 限制子弹数量2.7 创建方法_update_bullets() 1.前文总结回顾 1.1 alien…

java项目之汽车在线销售系统(ssm+mysql)

风定落花生&#xff0c;歌声逐流水&#xff0c;大家好我是风歌&#xff0c;混迹在java圈的辛苦码农。今天要和大家聊的是一款基于ssm的汽车在线销售系统。 开发环境&#xff1a; 后端&#xff1a; 开发语言&#xff1a;Java 框架&#xff1a;ssm&#xff0c;mybatis JDK版…

电脑提示找不到应用程序怎么办?

无论个人电脑还是办公电脑&#xff0c;无一例外的都会安装一些应用程序来帮助我们使用。而在电脑的使用过程中总会出现一些大大小小的问题&#xff0c;其中双击桌面快捷方式显示找不到应用程序是一个比较常见的故障。那么&#xff0c;电脑找不到应用程序怎么解决呢? 电脑找不到…

RabbitMQ学习笔记8 高级特性 消息可靠性+消费

我们在测试类中去写一个方法去实现它&#xff1a; 运行&#xff1a; 我们去掉之前的消息鉴定&#xff0c;我们这里不用消息鉴定。 我们注释掉这个。再去运行&#xff1a; 我们现在模拟一下发送失败的情况&#xff1a; 之前我们设置了我们交换机的名称。 我们在测试类发送消息时…

如何提高力扣(Leetcode)的解题能力?

如何提高力扣&#xff08;Leetcode&#xff09;的解题能力&#xff1f; 力扣&#xff08;Leetcode&#xff09;是一个在线编程平台&#xff0c;提供了各种算法和数据结构的题目&#xff0c;让程序员可以练习和提高自己的编程技能。很多人都把力扣&#xff08;Leetcode&#xf…

【脚本语言】Shell Script - 终端打印指令

目录 终端打印 基础语法 有趣的拓展 在echo中使用转义序列 输出彩色文本 终端打印 终端是交互式工具&#xff0c;在终端中打印文本是绝大多数脚本中的基本任务。 基础语法 终端打印有两种方法输出文本&#xff0c;分别是 echo 和 printf (就是C/C中的那个)。 在默认情况下…

Git---标签管理

文章目录 前言一、理解标签二、创建标签三、操作标签总结 前言 正文开始!!! 一、理解标签 标签tag,可以简单的理解为是对某次commit的一个标识,相当于起了一个别名.例如,在项目发布某个版本的时候,针对最后一次commit起一个v1.0这样的标签来标识里程碑的意义. 这有什么用呢?…

信息系统项目管理师(第四版)教材精读思维导图-第一章信息化发展

请参阅我的另一篇文章&#xff0c;综合介绍软考高项&#xff1a; 信息系统项目管理师&#xff08;软考高项&#xff09;备考总结_计算机技术与软件专业技术_铭记北宸的博客-CSDN博客 思维导图源文件下载&#xff1a; https://download.csdn.net/download/hanjingjava/8801629…

如何在工作中保持稳定的情绪

如何在工作中保持稳定的情绪 在高压的工作环境中&#xff0c;保持稳定的情绪对于程序员来说至关重要。作为一个程序员&#xff0c;我们常常面临着各种技术挑战、项目期限和团队合作的压力。在这样的环境下&#xff0c;情绪的波动可能会影响我们的工作效率和质量。因此&#xff…

使用OpenCV显示图像的RGB颜色直方图

#include <opencv2/opencv.hpp> #include <opencv2/imgproc/imgproc.hpp> using namespace cv;int main( ) {Mat srcImage;srcImage=<

数据特征降维 | 主成分分析PCA数据特征降维

文章目录 效果一览文章概述部分源码部分源码参考资料效果一览 文章概述 数据特征降维 | 主成分分析PCA,(主成分分析经常用于减少数据集的维数,同时保持数据集中的对方差贡献最大的特征) 部分源码 部分源码 %% 清空环境变量 warning off % 关闭报警信息 close a…