力扣爆刷第141天之二叉树十连刷(翻转、对称、深度、平衡、路径)

力扣爆刷第141天之二叉树十连刷(翻转、对称、深度、平衡、路径)

文章目录

      • 力扣爆刷第141天之二叉树十连刷(翻转、对称、深度、平衡、路径)
      • 一、226. 翻转二叉树
      • 二、101. 对称二叉树
      • 三、104. 二叉树的最大深度
      • 四、111. 二叉树的最小深度
      • 五、222. 完全二叉树的节点个数
      • 六、110. 平衡二叉树
      • 七、257. 二叉树的所有路径
      • 八、404. 左叶子之和
      • 九、513. 找树左下角的值
      • 十、112. 路径总和

一、226. 翻转二叉树

题目链接:https://leetcode.cn/problems/invert-binary-tree/description/
思路:直接前序遍历,然后在遍历的过程中交换左右子节点。

class Solution {public TreeNode invertTree(TreeNode root) {traverse(root);return root;}void traverse(TreeNode root) {if(root == null) return ;TreeNode t = root.left;root.left = root.right;root.right = t;traverse(root.left);traverse(root.right);}}

二、101. 对称二叉树

题目链接:https://leetcode.cn/problems/symmetric-tree/description/
思路:将一个棵二叉树当做两颗二叉树来遍历,也就是在递归的函数参数中携带左右两颗子树,然后进行比较。

class Solution {public boolean isSymmetric(TreeNode root) {return traverse(root.left, root.right);}boolean traverse(TreeNode node1, TreeNode node2) {if(node1 == null && node2 == null) return true;if(node1 == null || node2 == null) return false;if(node1.val != node2.val) return false;return traverse(node1.left, node2.right) && traverse(node1.right, node2.left);}}

三、104. 二叉树的最大深度

题目链接:https://leetcode.cn/problems/maximum-depth-of-binary-tree/description/
思路:后序遍历,返回左右子树的最大值即可,然后每返回一层就加1,即可得到最大深度。

class Solution {public int maxDepth(TreeNode root) {if(root == null) return 0;int left = maxDepth(root.left);int right = maxDepth(root.right);return Math.max(left, right) + 1;}
}

四、111. 二叉树的最小深度

题目链接:https://leetcode.cn/problems/minimum-depth-of-binary-tree/description/
思路:求最小深度,需要从上往下找,使用前序遍历,递归终点为叶子节点,到达叶子节点进行判断。

class Solution {int min = Integer.MAX_VALUE;public int minDepth(TreeNode root) {if(root == null) return 0;traverse(root, 1);return min;}void traverse(TreeNode root, int deep) {if(root == null) return;if(root.left == null && root.right == null) {min = Math.min(min, deep);return ;}traverse(root.left, deep+1);traverse(root.right, deep+1);}
}

五、222. 完全二叉树的节点个数

题目链接:https://leetcode.cn/problems/count-complete-tree-nodes/description/
思路:求完全二叉树的节点个数,思路很简单,就是利用完全二叉树的性质,可以根据深度计算个数,所以就前序遍历,每一个节点都判断是否是完全二叉树,是就不遍历了,不是再遍历。

class Solution {public int countNodes(TreeNode root) {if(root == null) return 0;int a = 0, b = 0;TreeNode p = root, q = root;while(p != null) {a++;p = p.left;}while(q != null) {b++;q = q.right;}if(a == b) return (int)Math.pow(2, a) - 1;return countNodes(root.left) + countNodes(root.right) + 1;}
}

六、110. 平衡二叉树

题目链接:https://leetcode.cn/problems/balanced-binary-tree/description/
思路:平衡二叉树是指左右子高度相差不超过1,所以直接按照求树的深度就可以解题,只要左右深度大于1,即不平衡。

class Solution {boolean flag = true;public boolean isBalanced(TreeNode root) {traverse(root);return flag;}int traverse(TreeNode root) {if(root == null) return 0;int left = traverse(root.left);int right = traverse(root.right);if(Math.abs(left - right) > 1) {flag = false;}return Math.max(left, right) + 1;}
}

七、257. 二叉树的所有路径

题目链接:https://leetcode.cn/problems/binary-tree-paths/description/
思路:求所有路径,这种题目在回溯中非常常见,所以本题也是在递归的过程中使用回溯,在叶子节点进行路径组装。

class Solution {List<String> result = new ArrayList<>();List<Integer> list = new ArrayList<>();public List<String> binaryTreePaths(TreeNode root) {traverse(root);return result;}void traverse(TreeNode root) {list.add(root.val);if(root.left == null && root.right == null) {StringBuilder sb = new StringBuilder();for(int i : list) {sb.append(i).append("->");}sb.delete(sb.length()-2, sb.length());result.add(sb.toString());return;}if(root.left != null) {traverse(root.left);list.remove(list.size()-1);}if(root.right != null) {traverse(root.right);list.remove(list.size()-1);}}
}

八、404. 左叶子之和

题目链接:https://leetcode.cn/problems/sum-of-left-leaves/description/
思路:求左叶子之和,求的是所有的左叶子的和,所以只需要做两件事情,一件是在叶子节点进行判断,另外一件是提供每个节点的信息,用于判断当前节点是否是叶子节点,这种信息需要从父节点传递,所以在递归函数的参数中。

class Solution {int sum = 0;public int sumOfLeftLeaves(TreeNode root) {traverse(root, false);return sum;}void traverse(TreeNode root, boolean flag) {if(root == null) return ;if(root.left == null && root.right == null && flag) {sum += root.val;}traverse(root.left, true);traverse(root.right, false);}
}

九、513. 找树左下角的值

题目链接:https://leetcode.cn/problems/find-bottom-left-tree-value/description/
思路:本题和上一题略有差异,上一题是求所有左叶子节点的和,要求的是左叶子节点,本题类似于树的左视图,但是是深度最深的哪一行的最左边的那个节点,它可能是左节点也可能是右节点。只需要前序遍历,利用深度,当深度第一次大于记录值时,说明是第一次到达下一层,而且采用的是前序遍历,到达的是下一层的最左边的叶子节点。

class Solution {int result = 0, max = 0;public int findBottomLeftValue(TreeNode root) {traverse(root, 1);return result;}void traverse(TreeNode root, int deep) {if(root == null) return ;if(root.left == null && root.right == null && deep > max) {max = deep;result = root.val;} traverse(root.left, deep + 1);traverse(root.right, deep + 1);}
}

十、112. 路径总和

题目链接:https://leetcode.cn/problems/path-sum/description/
思路:求路径总和,类似于回溯的用法,就是在树的递归过程中使用回溯,如果是全局变量,需要手动回滚数据,如果是携带是函数参数列表则不需要。

class Solution {boolean flag = false;public boolean hasPathSum(TreeNode root, int targetSum) {traverse(root, targetSum, 0);return flag;}void traverse(TreeNode root, int targetSum, int sum) {if(root == null || flag) return;sum += root.val;if(root.left == null && root.right == null) {if(sum == targetSum) flag = true;}traverse(root.left, targetSum, sum);traverse(root.right, targetSum, sum);}
}

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

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

相关文章

【Qt QML】Dialog组件

带有标准按钮和标题的弹出对话框&#xff0c;用于与用户进行短期交互。 这个描述指的是一个常见的用户界面元素&#xff0c;即一个临时弹出的窗口&#xff08;或对话框&#xff09;&#xff0c;它包含一个标题&#xff0c;显示对话框的用途或内容描述&#xff0c;以及一系列标…

[数据集][目标检测]航空发动机缺陷检测数据集VOC+YOLO格式291张4类别

数据集格式&#xff1a;Pascal VOC格式YOLO格式(不包含分割路径的txt文件&#xff0c;仅仅包含jpg图片以及对应的VOC格式xml文件和yolo格式txt文件) 图片数量(jpg文件个数)&#xff1a;291 标注数量(xml文件个数)&#xff1a;291 标注数量(txt文件个数)&#xff1a;291 标注类别…

Kyndryl 与 Nvidia 建立新的人工智能基础设施合作伙伴关系

Kyndryl与Nvidia宣布达成新的人工智能基础设施战略合作&#xff0c;共同推动AI技术的广泛应用。根据这一合作&#xff0c;Nvidia的先进AI软件解决方案将被引入Kyndryl的开放集成平台——Kyndryl Bridge&#xff0c;以优化基础设施工作负载&#xff0c;并为客户提供更高效的IT服…

AUS GLOBAL 与 UNICEF 联合国儿童基金会共同帮助叙利亚和土耳其地震受灾居民

2023年2月6日,土耳其东南部和叙利亚发生两次强烈地震和数十次余震,数以千计的儿童和家庭面临危机。 成千上万的房屋被毁,许多家庭被迫流离失所,而在一年中的这个时候,气温经常低于冰点,雪和冻雨很常见。许多学校、医院以及其他医疗和教育设施被地震破坏或摧毁,这对儿童造成了巨…

mongodb数据库备份到远程机器

一、背景 生产环境的mongodb数据库是直接购买阿里云的云数据库&#xff0c;但是在公司研发环境&#xff0c;我们是自己手动部署的。开发和测试的数据当然没有生产环境那么重要&#xff0c;但备份也是必要的&#xff0c;只不过容忍一定的数据丢失。 二、备份脚本 vi /etc/cro…

SpringCloud Alibaba Nacos分类配置--多方案配置隔离

文章目录 Nacos 分类配置(实现配置隔离)1.DataID 方案需求分析/图解配置实现测试 2.Group 方案需求分析/图解配置实现修改application.yml修改bootstrap.yml测试 3.Namespace 方案需求分析/图解配置实现修改application.yml修改bootstrap.yml测试 Namespace/Group/Data ID 关系…

MySQL连表查询练习

– 34. 查询所有员工的姓名和部门名称&#xff0c;没有部门的员工不需要展示 SELECTe.NAME 员工姓名,d.NAME 部门名称 FROMt_emp eINNER JOIN t_dept d ON e.dept_id d.id;– 35. 查询所有员工的姓名和部门名称&#xff0c;没有部门的员工展示BOSS SELECTe.NAME 员工姓名,i…

揭秘:如何使用Python统计女友生日还剩几天?

新书上架~&#x1f447;全国包邮奥~ python实用小工具开发教程http://pythontoolsteach.com/3 欢迎关注我&#x1f446;&#xff0c;收藏下次不迷路┗|&#xff40;O′|┛ 嗷~~ 目录 一、引言&#xff1a;为何需要统计生日天数&#xff1f; 二、需求分析与准备 1. 用户输入格…

智慧景区ar导览小程序系统开发搭建

开发智慧景区AR导览小程序系统需要以下几个步骤&#xff1a; 1. 确定需求和功能&#xff1a;了解景区需求&#xff0c;包括AR导览的区域、设备、应用场景等&#xff0c;并根据需求制定功能需求清单。 2. 选择合适的AR技术&#xff1a;智慧景区AR导览需要利用AR技术实现实景与…

Hudi Flink MOR 学习总结

前言 之前很少用MOR表,现在来学习总结一下。首先总结一下 compaction 遇到的问题。 版本 Flink 1.15.4Hudi 0.13.0表类型 COW 和 MOR COW:COW COPY_ON_WRITE 写时复制,写性能相比于MOR表差一点,因为每次写数据都会合并文件,但是能及时读取到最新的表数据。数据文件只有…

自适应星空背景个人导航单页(附带源码)

自适应星空背景个人导航单页 效果图部分源码领取源码下期更新预报 效果图 部分源码 function Star(id, x, y) {this.id id;this.x x;this.y y;this.r Math.floor(Math.random() * 2) 1;var alpha (Math.floor(Math.random() * 10) 1) / 10 / 2;this.color "rgba(…

shell脚本的基础应用

规范脚本的构成 #&#xff01;/bin/bash # 注释信息 可执行的语句 执行脚本的方法 有1.添加x权限 ,绝对路经&#xff0c;或者相对路径2. 使用解释器 不需加x,root...bash...bash..echo 3,用source&#xff0c; 开机root ...bash ...echo bash -x /opt/test01.sh &#xff…

【算法】递归、搜索与回溯——汉诺塔

题解&#xff1a;汉诺塔(递归、搜索与回溯算法) 目录 1.题目2.题目背景(拓展了解)3.题解4.参考代码5.细节6.总结 1.题目 题目链接&#xff1a;LINK 2.题目背景(拓展了解) 汉诺塔问题是一个通过隐式使用递归栈来进行实现的一个经典问题&#xff0c;该问题最早的发明人是法国…

AI新时代的对决:OpenAI GPT-4o与Google Astra的较量

随着人工智能技术的飞速发展&#xff0c;两大巨头OpenAI和Google在近期分别推出了他们引人瞩目的新产品——GPT-4o和Project Astra。这场看似悄然而至&#xff0c;实则全球瞩目的竞赛&#xff0c;无疑预示着AI领域的重大突破和未来智能助理的新格局。 OpenAI的GPT-4o自宣布以来…

node_相关知识点

Node.js采用谷歌的V8引擎&#xff0c;是一个服务器端的、非阻断式I/O的、事件驱动的JavaScript运行环境&#xff0c;可优化应用程序的传输量和规模。传统服务器多线程&#xff08;一个请求一个线程&#xff09;易阻塞。 一、线程、进程&#xff1a; 进程&#xff1a;进程负责…

【从零开始学习RabbitMQ | 第二篇】如何确保MQ的可靠性和消费者可靠性

目录 前言&#xff1a; MQ可靠性&#xff1a; 数据持久化&#xff1a; Lazy Queue&#xff1a; 消费者可靠性&#xff1a; 消费者确认机制&#xff1a; 消费失败处理&#xff1a; MQ保证幂等性&#xff1a; 方法一&#xff1a; 总结&#xff1a; 前言&#xff1a; …

如何在Java中实现单例模式

一、引言 单例模式&#xff08;Singleton Pattern&#xff09;是Java中最常用的设计模式之一。它的主要目的是确保一个类只有一个实例&#xff0c;并提供一个全局访问点。在许多场景下&#xff0c;如配置管理、线程池、数据库连接池等&#xff0c;单例模式都能发挥重要作用。 …

Debian12 安装留档@Virtual Box

在学蜜罐系统的时候&#xff0c;T-Pot 需要Debian&#xff0c;于是安装Debian12 下载安装光盘 先去中科大下载了12的安装光盘&#xff0c;然后在VirtualBox中创建一个新虚拟机&#xff0c;将安装光盘挂载上。 安装光盘下载地址&#xff1a;https://mirrors.ustc.edu.cn/debi…

【NumPy】全面解析NumPy的bitwise_and函数:高效按位与操作指南

&#x1f9d1; 博主简介&#xff1a;阿里巴巴嵌入式技术专家&#xff0c;深耕嵌入式人工智能领域&#xff0c;具备多年的嵌入式硬件产品研发管理经验。 &#x1f4d2; 博客介绍&#xff1a;分享嵌入式开发领域的相关知识、经验、思考和感悟&#xff0c;欢迎关注。提供嵌入式方向…

算法训练 | 二叉树Part7 | 530.二叉搜索树的最小绝对差、501.二叉搜索树中的众数

目录 530.二叉搜索树的最小绝对差 数组法 双指针法 ⭐ 迭代法 501.二叉搜索树中的众数 双指针法 迭代法 530.二叉搜索树的最小绝对差 题目链接&#xff1a;530. 二叉搜索树的最小绝对差 - 力扣&#xff08;LeetCode&#xff09; 文章讲解&#xff1a;代码随想录 数组…