一个函数来数这个root下一共多少node 非常简单 recursive
然后就是主函数中判断left有多少node的时候需要数右边 想清楚 +1 -1的事情 因为要算上root本身
public class Solution {
public int kthSmallest(TreeNode root, int k) {
if ( countNode ( root.left ) < k - 1)
return kthSmallest( root.right, k - 1 - countNode( root.left) );
else if ( countNode ( root.left ) >= k)
return kthSmallest( root.left, k);
else
return root.val;
}
public int countNode ( TreeNode node ){
if ( node == null )
return 0;
return 1 + countNode ( node.left ) + countNode ( node.right );
}
}

本文详细介绍了使用递归方法在二叉树中计算节点总数及查找第K小节点的过程,包括核心函数实现与边界条件处理。
313

被折叠的 条评论
为什么被折叠?



