首页 > 其他 > 详细

Populating Next Right Pointers in Each Node II

时间:2014-05-30 16:18:32      阅读:368      评论:0      收藏:0      [点我收藏+]

Follow up for problem "Populating Next Right Pointers in Each Node".

What if the given tree could be any binary tree? Would your previous solution still work?

Note:

  • You may only use constant extra space.

 

For example,
Given the following binary tree,

         1
       /        2    3
     / \        4   5    7

 

After calling your function, the tree should look like:

         1 -> NULL
       /        2 -> 3 -> NULL
     / \        4-> 5 -> 7 -> NULL
bubuko.com,布布扣
/**
 * Definition for binary tree with next pointer.
 * struct TreeLinkNode {
 *  int val;
 *  TreeLinkNode *left, *right, *next;
 *  TreeLinkNode(int x) : val(x), left(NULL), right(NULL), next(NULL) {}
 * };
 */
class Solution {
public:
    void connect(TreeLinkNode *root) 
    {
        vector<TreeLinkNode*> list;
        if(root==NULL) return;
        
        list.push_back(root);
        while(list.size()>0)
        {
            vector<TreeLinkNode*> children;
            for(int i=0;i<list.size();i++)
            {
                if(list[i]->left!=NULL) 
                {
                    children.push_back(list[i]->left);
                    if(children.size()>1) children[children.size()-2]->next=children[children.size()-1];
                }
                if(list[i]->right!=NULL) 
                {
                    children.push_back(list[i]->right);
                    if(children.size()>1) children[children.size()-2]->next=children[children.size()-1];
                }
            }
            list=children;
        }
    }
};
bubuko.com,布布扣

 

Populating Next Right Pointers in Each Node II,布布扣,bubuko.com

Populating Next Right Pointers in Each Node II

原文:http://www.cnblogs.com/erictanghu/p/3759655.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!