java计算二叉树的节点最小值

阅读: 评论:0

java计算二叉树的节点最小值

java计算二叉树的节点最小值

题目:

Given a complete binary tree, count the number of nodes.

Definition of a complete binary tree from Wikipedia:

In a complete binary tree every level, except possibly the last, is completely filled, and all nodes in the last level are as far left as possible. It can have between 1 and 2h nodes

inclusive at the last level h.

解题:

假设用常规的解法一个个遍历,就是O(n)时间复杂度 。会不通过,这边就不写O(n)的代码了。由于是全然二叉树,满二叉树有一个性质是节点数等于2^h-1,h为高度,所以能够这样推断节点的左右高度是不是一样,假设是一样说明是满二叉树,就能够用刚才的公式。假设左右不相等就递归计算左右节点。

代码:

public static int countNodes(TreeNode root) {

if(root==null)

return 0;

else {

int left=getLeftHeight(root);

int right=getRightHeight(root);

if(left==right)

return (1<

else {

return countNodes(root.right)+countNodes(root.left)+1;

}

}

}

public static int getRightHeight(TreeNode root) {

int height=0;

while(root!=null)

{

height++;

root=root.left;

}

return height;

}

public static int getLeftHeight(TreeNode root) {

int height=0;

while(root!=null)

{

height++;

root=root.right;

}

return height;

}

本文发布于:2024-01-28 07:39:55,感谢您对本站的认可!

本文链接:https://www.4u4v.net/it/17063988005849.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

标签:节点   最小值   二叉树   java
留言与评论(共有 0 条评论)
   
验证码:

Copyright ©2019-2022 Comsenz Inc.Powered by ©

网站地图1 网站地图2 网站地图3 网站地图4 网站地图5 网站地图6 网站地图7 网站地图8 网站地图9 网站地图10 网站地图11 网站地图12 网站地图13 网站地图14 网站地图15 网站地图16 网站地图17 网站地图18 网站地图19 网站地图20 网站地图21 网站地图22/a> 网站地图23