当前位置: 首页 > article >正文

代码随想录第十五天| 110.平衡二叉树 、 257. 二叉树的所有路径 、404.左叶子之和、222.完全二叉树的节点个数

110. 平衡二叉树

题目描述

给定一个二叉树,判断它是否是平衡二叉树。平衡二叉树的定义是:对于每个节点,其左右子树的高度差不超过1。

解题思路
  1. 递归求高度:设计一个递归函数 getHeight,用于计算每个节点的高度,同时在递归过程中判断该节点的左右子树是否平衡。
  2. 平衡性判断:在 getHeight 函数中,如果当前节点的左右子树高度差超过1,则直接返回 -1,表示该子树不平衡。
  3. 终止条件:当某个子树不平衡时,递归会一路返回 -1,最终使 isBalanced 方法返回 false
  4. 递归返回高度:如果左右子树平衡,则 getHeight 返回节点的高度(即 1 + Math.max(leftHeight, rightHeight)),用于上层判断。
代码实现
class Solution {
	public int  getHeight(TreeNode node){
		if(node==null){
			return 0;
		}
		int leftHeight = getHeight(node.left);
		if(leftHeight==-1){
			return -1;
		}
		int rightHeight = getHeight(node.right);
		if(rightHeight==-1){
			return -1;
		}
		int result;
		if(Math.abs(rightHeight-leftHeight)>1){
			return -1;
		}else {
			result = 1+Math.max(rightHeight,leftHeight);
		}
		return result;
	}
    public boolean isBalanced(TreeNode root) {
		int result = getHeight(root);
		if(result==-1){
			return false;
		}else {
			return true;
		}
    }
}

257. 二叉树的所有路径

题目描述

给定一个二叉树,返回所有从根节点到叶子节点的路径。

解题思路
  1. 深度优先遍历:使用深度优先遍历(DFS)方法遍历二叉树,记录每条从根到叶子的路径。
  2. 路径存储:定义一个列表 paths 用于存储当前路径中的节点值,当遍历到叶子节点时,将路径拼接成字符串并加入结果列表 res 中。
  3. 回溯:每次递归返回上层节点时,从 paths 中移除最后一个节点值,以回溯至之前的状态,继续生成其他路径。
代码实现
class Solution {
    public List<String> binaryTreePaths(TreeNode root) {
        List<String> res = new ArrayList<>();
		if(root==null){
			return res;
		}
		List<Integer> paths = new ArrayList<>();
		traversal(root,paths,res);
		return res;
    }
	public void traversal(TreeNode root,List<Integer> paths,List<String> res) {
		paths.add(root.val);
		if(root.left == null && root.right == null){
			StringBuilder sb = new StringBuilder();
			for(int i=0;i<paths.size()-1;i++){
				sb.append(paths.get(i)).append("->");
			}
			sb.append(paths.get(paths.size()-1));
			res.add(sb.toString());
			return;
		}

		if(root.left != null){
			traversal(root.left,paths,res);
			paths.remove(paths.size()-1);
		}
		if(root.right != null){
			traversal(root.right,paths,res);
			paths.remove(paths.size()-1);
		}
	}
}

404. 左叶子之和

题目描述

计算给定二叉树的所有左叶子节点的和。左叶子节点是指在父节点的左子树中且没有子节点的节点。

解题思路
  1. 递归遍历:使用递归方式遍历每个节点,分别计算左子树和右子树中左叶子节点的和。
  2. 判断左叶子节点:在递归过程中,如果一个节点的左子节点存在且是叶子节点(即没有左右子节点),则将其值加入左叶子和中。
  3. 递归返回和:每个节点返回的结果是该节点下所有左叶子节点的和,递归最终得到整棵树的左叶子和。
代码实现
class Solution {
    public int sumOfLeftLeaves(TreeNode root) {
		if(root==null){
			return 0;
		}
		if(root.left==null && root.right==null){
			return 0;
		}
		int leftvalue = sumOfLeftLeaves(root.left);
		if(root.left != null && root.left.left == null && root.left.right == null){
			leftvalue = root.left.val;
		}
		int rightvalue = sumOfLeftLeaves(root.right);
		return leftvalue+rightvalue;
    }
}

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

题目描述

给定一个完全二叉树,求出该树的节点总数。

解题思路
  1. 递归计数法

    • 使用简单的递归方法,分别统计左子树和右子树的节点数,加上根节点,即可得到总节点数。
    • 时间复杂度为 O(n),其中 n 是节点总数。
  2. 利用完全二叉树特性优化

    • 计算完全二叉树的左深度 leftDepth 和右深度 rightDepth
    • 如果左右深度相等,则整棵树是满二叉树,其节点数为 ( 2^{\text{leftDepth} + 1} - 1 )。
    • 如果左右深度不相等,递归计算左子树和右子树的节点数之和。
    • 这种方法利用了完全二叉树的结构特性,降低了时间复杂度。
代码实现
class Solution {
    public int countNodes(TreeNode root) {
        if(root==null){
			return 0;
		}
		int leftnode =countNodes(root.left);
		int rightnode =countNodes(root.right);
		return leftnode+rightnode+1;
    }
}
class Solution {
    public int countNodes(TreeNode root) {
        if(root==null){
			return 0;
		}
		TreeNode left = root.left;
		TreeNode right = root.right;
		int leftDepth =0,rightDepth =0;
		while(left!=null){
			left = left.left;
			leftDepth++;
		}
		while(right!=null){
			right = right.right;
			rightDepth++;
		}
		if(leftDepth==rightDepth){
			return (2 << leftDepth)-1;
		}
		int leftnode = countNodes(root.left);
		int rightnode = countNodes(root.right);
		return leftnode+rightnode+1;
    }
}

http://www.kler.cn/a/379564.html

相关文章:

  • CryptoMamba:利用状态空间模型实现精确的比特币价格预测
  • 网络基础知识指南|1-20个
  • Leetcode 377. 组合总和 Ⅳ 动态规划
  • 【Elasticsearch复合查询】
  • 【Rust自学】12.3. 重构 Pt.1:改善模块化
  • 统计有序矩阵中的负数
  • 基于深度学习的数据安全与可追溯性增强
  • qt QPixmap详解
  • 深入了解 Kotlin 高阶函数
  • SpringBoot实现:高效在线试题库系统
  • koa + sequelize做距离计算(MySql篇)
  • 使用WordPress快速搭建个人网站
  • 汽车电子行业数字化转型的实践与探索——以盈趣汽车电子为例
  • Python酷库之旅-第三方库Pandas(193)
  • 【工具变量】中国制造2025试点城市数据集(2000-2023年)
  • Maven核心概念
  • Linux-计算机网络-epoll的LT,ET模式
  • 力扣150:逆波兰表达式求值
  • 使用Web Workers实现JavaScript的多线程编程
  • 【WebRTC】WebRTC的简单使用
  • 【嵌入式面试高频知识点】-MQTT协议
  • 【appium 安卓10 QQ发送消息】
  • 不用买PSP,画质甚至更好,这款免费神器让你玩遍经典游戏
  • 基于卷积神经网络的棉花病虫害识别与防治系统,resnet50,mobilenet模型【pytorch框架+python源码】
  • Spring的常用注解之@Component——day1
  • 【Keyframes】Deep Convolutional Pooling Transformer for Deepfake Detection