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

LeetCode "Count Complete Tree Nodes"

时间:2015-06-06 06:48:24      阅读:124      评论:0      收藏:0      [点我收藏+]

标签:

DFS solution is intuitive. I put my BFS solution below:

class Solution {
public:
    int countNodes(TreeNode* root) 
    {
        if (!root) return 0;
        
        //  Case 1: complete
        int hl = 0, hr = 0;
        TreeNode *pl = root;
        while(pl)
        {
            hl ++;
            pl = pl->left;
        }
        TreeNode *pr = root;
        while(pr)
        {
            hr ++;
            pr = pr->right;
        }
        if (hl == hr)
        {
            return pow(2, hl) - 1;
        }
        
        //  Case 2: incomplete
        deque<TreeNode *> q;
        q.push_back(root);
        int pcnt = 1;
        int level = 0;
        
        while(!q.empty())
        {
            auto ptop = q.front();
            q.pop_front();
            pcnt --;

            if (ptop->left)
                q.push_back(ptop->left);
            if (ptop->right)
                q.push_back(ptop->right);

            if(pcnt == 0)
            {
                pcnt = q.size();
                level ++;
                if (level == hr)
                {
                    break;
                }
            }
        }

        return pow(2, hr) - 1 + pcnt;
    }
};

LeetCode "Count Complete Tree Nodes"

标签:

原文地址:http://www.cnblogs.com/tonix/p/4555991.html

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