码迷,mamicode.com
首页 > 其他好文 > 详细

【Leetcode】222. Count Complete Tree Nodes

时间:2018-03-13 12:11:30      阅读:117      评论:0      收藏:0      [点我收藏+]

标签:判断   treenode   node   特性   tween   子节点   递归   blank   ret   

Question:

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.


Tips:

给定一个完全二叉树,求树中结点的个数。

思路:

完全二叉树的特性:完全二叉树:叶节点只能出现在最下层和次下层,并且最下面一层的结点都集中在该层最左边的若干位置的二叉树。即除了最后一层,前面所有层必须是满二叉树。这样我们就只要找到最后一层几个叶子节点就可以判断树中结点的数量。

只有当左右子树高度想同的时候,才能知道该节点之前的树是满的。

当左右子树高度不相等,采用递归的办法,来判断其做左右子树的高度是否相等。

代码:

//根据完全二叉树的特性 除最后一排 前面的树是满二叉树。
    public int countNodes(TreeNode root) {
        if (root == null)
            return 0;
        int ans=0;
        int left=getLeft(root);
        int right=getRight(root);
        if(left==right){
            return (1<<left)-1;
        }else
        return 1+countNodes(root.left)+countNodes(root.right);
    }

    private int getLeft(TreeNode root) {
        int h=0;
        while(root!=null){
            h++;
            root=root.left;
        }
        return h;
    }
    private int getRight(TreeNode root) {
        int h=0;
        while(root!=null){
            h++;
            root=root.right;
        }
        return h;
    }

 

【Leetcode】222. Count Complete Tree Nodes

标签:判断   treenode   node   特性   tween   子节点   递归   blank   ret   

原文地址:https://www.cnblogs.com/yumiaomiao/p/8555162.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!