LeetCode Java刷题笔记—104. 二叉树的最大深度
Posted 刘Java
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了LeetCode Java刷题笔记—104. 二叉树的最大深度相关的知识,希望对你有一定的参考价值。
104. 二叉树的最大深度
给定一个二叉树,找出其最大深度。二叉树的深度为根节点到最远叶子节点的最长路径上的节点数。说明: 叶子节点是指没有子节点的节点。
简单难度。这道题很简单,采用分治算法即可。所谓分治(Divide and Conquer)算法,就是先分别处理局部,再合并结果,分(divide)阶段将问题分成一些小的问题然后递归求解,而治(conquer)的阶段则将分的阶段得到的各答案"合并"在一起,即分而治之。
这里,我们首先递归到每个叶子节点,就是拆分,然后再返回,合并的时候比较并选择值更大的节点的深度+1返回,这样就能求得最大深度。
public int maxDepth( TreeNode root )
return root == null ? 0 : Math.max( maxDepth( root.left ), maxDepth( root.right ) ) + 1;
上面是三元运算符,下面是一个更容易看懂的版本:
public int maxDepth( TreeNode root )
if( root == null )
return 0;
/*分 拆解*/
int left = maxDepth( root.left );
int right = maxDepth( root.right );
/*治 合并*/
//返回较大的值+1的结果,表示最大深度增加1
if( left >= right )
return left + 1;
return right + 1;
以上是关于LeetCode Java刷题笔记—104. 二叉树的最大深度的主要内容,如果未能解决你的问题,请参考以下文章
LeetCode Java刷题笔记— 111. 二叉树的最小深度
LeetCode Java刷题笔记— 111. 二叉树的最小深度