news 2026/4/15 23:07:12

A.每日一题——865. 具有所有最深节点的最小子树

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
A.每日一题——865. 具有所有最深节点的最小子树

题目链接:865. 具有所有最深节点的最小子树(中等)

完全相同的题目:1123. 最深叶节点的最近公共祖先(中等)

算法原理:

解法一:递归—整体看

0ms击败100.00%

时间复杂度O(N)

①递归二叉树,同时逐步更新全局最大深度

②“递”的时候往下传该节点的深度depth

③“归”的时候往上带回该节点所在子树的最深深度

④如果左右子树的最深深度与当前全局最深深度相同,那么我们可以更新待返回的结果,但这不能直接返回,是因为这很可能不是最深的叶子节点所在子树,如果后面还有更深的,还会继续更新

解法二:自底而上—局部看

0ms击败100.00%

时间复杂度O(N)

也可以不用全局变量记录整棵树的高度,而是把每棵子树都看成一个个子问题

left高度>right高度时,node子树高度为left高度+1,最近公共祖先是左子树的最近公共祖先

left高度<right高度时,node子树高度为right高度+1,最近公共祖先是右子树的最近公共祖先

left高度=right高度时,node子树高度为left高度+1,最近公共祖先就是node

Java代码:

/** * Definition for a binary tree node. * public class TreeNode { * int val; * TreeNode left; * TreeNode right; * TreeNode() {} * TreeNode(int val) { this.val = val; } * TreeNode(int val, TreeNode left, TreeNode right) { * this.val = val; * this.left = left; * this.right = right; * } * } */ //解法一:递归 class Solution { private int maxdepth=-1;//全局最大深度 private TreeNode ret; public TreeNode subtreeWithAllDeepest(TreeNode root) { dfs(root,0); return ret; } private int dfs(TreeNode node,int depth){ if(node==null){ maxdepth=Math.max(maxdepth,depth); return depth; } int leftdepth=dfs(node.left,depth+1); int rightdepth=dfs(node.right,depth+1); //当leftdepth==rightdepth==maxdepth时,node就是目前最佳答案 if(leftdepth==rightdepth&&leftdepth==maxdepth) ret=node; return Math.max(leftdepth,rightdepth);//往回带最深的深度 } }
/** * Definition for a binary tree node. * public class TreeNode { * int val; * TreeNode left; * TreeNode right; * TreeNode() {} * TreeNode(int val) { this.val = val; } * TreeNode(int val, TreeNode left, TreeNode right) { * this.val = val; * this.left = left; * this.right = right; * } * } */ //解法二:自底而上 class Solution { //自定义记录类:Java 16+支持record //作用:一次返回两个关键信息(最大高度,最近公共祖先) private record Pair(int height,TreeNode lca){} public TreeNode subtreeWithAllDeepest(TreeNode root) { //调用dfs获取整棵树的高度和对应LCA,直接返回LCA即可 return dfs(root).lca(); } //后序遍历:计算当前子树的高度+所有最深节点的LCA private Pair dfs(TreeNode node){ //递归出口:空节点,空树高度为0,没有节点,所以LCA为null if(node==null) return new Pair(0,null); Pair left=dfs(node.left); Pair right=dfs(node.right); //情况一:左子树最大高度>右子树最大高度 //说明最深节点在左子树中 //当前子树高度=左子树最大高度+1,LCA为左子树的LCA if(left.height()>right.height()) return new Pair(left.height()+1,left.lca()); //情况二:左子树最大高度<右子树最大高度 if(left.height()<right.height()) return new Pair(right.height()+1,right.lca()); //情况三:左右子树最大高度相等 //说明最深节点同时分布在左右子树中->当前节点就是最近公共祖先 //当前子树高度=左/右子树高度+1 return new Pair(left.height()+1,node); } }
/** * Definition for a binary tree node. * public class TreeNode { * int val; * TreeNode left; * TreeNode right; * TreeNode() {} * TreeNode(int val) { this.val = val; } * TreeNode(int val, TreeNode left, TreeNode right) { * this.val = val; * this.left = left; * this.right = right; * } * } */ //解法二的第二种写法,博主觉得比前一种写法更易懂一些 class Solution { public TreeNode subtreeWithAllDeepest(TreeNode root) { return dfs(root).getValue(); } private Pair<Integer,TreeNode> dfs(TreeNode node){ if(node==null) return new Pair<>(0,null); Pair<Integer,TreeNode> left=dfs(node.left); Pair<Integer,TreeNode> right=dfs(node.right); if(left.getKey()>right.getKey()) return new Pair(left.getKey()+1,left.getValue()); if(left.getKey()<right.getKey()) return new Pair(right.getKey()+1,right.getValue()); return new Pair(left.getKey()+1,node); } }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/10 9:09:59

ResNet18快速部署:一键启动的物体识别API

ResNet18快速部署&#xff1a;一键启动的物体识别API 1. 章节概述 在当前AI应用快速落地的时代&#xff0c;通用图像分类作为计算机视觉的基础能力&#xff0c;广泛应用于内容审核、智能相册、自动驾驶感知系统等场景。然而&#xff0c;许多开发者面临模型部署复杂、依赖网络…

作者头像 李华
网站建设 2026/4/14 11:56:20

ResNet18实战教程:工业零件识别系统搭建

ResNet18实战教程&#xff1a;工业零件识别系统搭建 1. 引言 1.1 学习目标 本文将带你从零开始&#xff0c;基于 TorchVision 官方 ResNet-18 模型&#xff0c;搭建一个高稳定性、低延迟的通用图像分类系统。你将掌握&#xff1a; 如何加载预训练模型并进行推理构建轻量级 …

作者头像 李华
网站建设 2026/3/31 17:25:40

ResNet18物体识别实战:从环境配置到应用部署

ResNet18物体识别实战&#xff1a;从环境配置到应用部署 1. 引言&#xff1a;通用物体识别中的ResNet-18价值 在计算机视觉领域&#xff0c;通用物体识别是构建智能系统的基础能力之一。无论是图像搜索、内容审核&#xff0c;还是增强现实与自动驾驶&#xff0c;精准理解图像…

作者头像 李华
网站建设 2026/4/14 10:17:28

ResNet18部署案例:工厂生产线质检系统实战

ResNet18部署案例&#xff1a;工厂生产线质检系统实战 1. 引言&#xff1a;从通用识别到工业质检的跨越 在智能制造快速发展的今天&#xff0c;自动化视觉质检已成为工厂提升效率、降低人工成本的核心环节。传统质检依赖人工目视检查&#xff0c;存在主观性强、疲劳误判等问题…

作者头像 李华
网站建设 2026/4/1 0:25:21

ResNet18部署指南:嵌入式设备图像识别方案

ResNet18部署指南&#xff1a;嵌入式设备图像识别方案 1. 背景与应用场景 在边缘计算和嵌入式AI快速发展的今天&#xff0c;如何在资源受限的设备上实现高效、稳定的图像识别成为关键挑战。通用物体识别作为计算机视觉的基础任务&#xff0c;广泛应用于智能安防、工业检测、智…

作者头像 李华