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

二叉树中的最长交错路径

题目链接

二叉树中的最长交错路径

题目描述



注意点

  • 每棵树最多有 50000 个节点
  • 每个节点的值在 [1, 100] 之间
  • 起点无需是根节点

解答思路

  • 要找到最长交错路径,首先想到的是深度优先遍历
  • 因为起点无需是根节点,所以对于任意一个节点,其可以选择两条路径(对应其左右子树):
    • 如果到达子树的方向与父节点到达该节点的方向相反,则到达该子树是交错路径,可以根据到达该节点的长度len计算
    • 如果到达子树的方向与父节点到达该节点的方向相同,则如果要到达该子树,只能将当前节点视作起点,之前到达该节点的长度不做贡献,长度重置为1

代码

/*** 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 {int res = 0;public int longestZigZag(TreeNode root) {if (root == null) {return 0;}dfs(root.left, true, 1);dfs(root.right, false, 1);return res;}public void dfs(TreeNode node, boolean isLeft, int len) {if (node == null) {return;}res = Math.max(res, len);if (isLeft) {dfs(node.right, false, len + 1);dfs(node.left, true, 1);} else {dfs(node.right, false, 1);dfs(node.left, true, len + 1);}}
}

关键点

  • 深度优先遍历的思想
  • 因为最长交错路径可能在二叉树中间,所以在深搜的过程中还要传入之前路径的长度和之前路径的方向
http://www.lryc.cn/news/463558.html

相关文章:

  • 高校企业数据可视化平台功能介绍/特色功能
  • RHCE第三次笔记SSH
  • JAVA基础-包装类
  • 复合逻辑运算与复合逻辑门
  • 工厂模式~
  • Elasticsearch基本使用及介绍
  • 10. PH47代码框架文件组织
  • LabVIEW提高开发效率技巧----VI继承与重载
  • 4.8 大数据发展趋势
  • 【无标题】react组件封装
  • git+cmake将Open3D配置到visual studio
  • ArcGIS-CityEngine 2024-新手小白也能试用+入门可视化vga编程--第一篇
  • IntelliJ IDEA 快捷键大全(也适用全家桶其他编辑器)
  • 基于SSM高校普法系统的设计
  • CDN加速流程分享
  • 全网爆火的排队免单模式究竟是如何运作?
  • Excel:vba实现批量修改文件名
  • 【数据分享】中国历史学年鉴(1979-2001)
  • ubuntu系统启动wmplayer提示vmware unable to install all modules的处理方法
  • 数据库原理与应用(基于MySQL):实验六数据查询
  • 【java面经thinking】二
  • 正规方程推导,详细版
  • 【原创】java+ssm+mysql在线文件管理系统设计与实现
  • cocos Creator + fairyGUI 快速入门
  • UICollectionView 的UICollectionReusableView复用 IOS18报错问题记录
  • Ansible Roles与优化
  • Ubuntu 22.04上安装Miniconda
  • 【MySQL】入门篇—SQL基础:数据定义语言(DDL)
  • 电影评论网站开发:Spring Boot技术详解
  • 20240817 全志 笔试