[レベル]の各ノードに移入次の右ポインタをトラバース

それを行うための再帰と議論するために、完全なバイナリツリー、優れているので、私は、この1回の交流を所有しています。

ACコード:

/**
 * 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 setNext(TreeLinkNode *h, int isLeft, TreeLinkNode *pre)
    {
        if(isLeft==1)
            h->next=pre->right;
        else
        {
            if(pre==NULL)
                h->next=NULL;
            else
                h->next=pre->left;
        }
        //对它下面的结点进行递归
        if(h->left==NULL && h->right==NULL)
            return;
        else
        {
            setNext(h->left,1,h);
            setNext(h->right,0,h->next);
        }
    }
    
    void connect(TreeLinkNode *root) {
        //思路:setNext(h,isleft,pre) //isleft=1则为左,传入共同根节点指向pre->right;
                                     //isleft=0则为右,传入根节点->next指向next->left,若pre为空则指向空
        if(root==NULL)
            return;
        if(root->left==NULL && root->right==NULL)
            return;
        setNext(root->left,1,root);
        setNext(root->right,0,NULL);
    }
};


 

各ノードIIで次の右ポインタの取り込み

一般的な考え方:

さらに議論最初の質問に基づいてコード内の情報(パスルートとroot->次の二つのポインタ、および個別に扱わ空の宣告を)したいが、「あまりにも多くの再帰タイムアウト+」の問題がありました。

これは、突然実現問題への解決策を見てレベルのトラバース各階層ノード接続用。キュー内に実装されています。

しかし、判定条件は、私の最初に考え疲れありさ:q.size()== 0は、ノードが層の右端に達したことを意味し、その次= NULLを設定します。私は層の各ポイントを処理すると、その後も次の設定する必要があります。しかし、良い点と考えていなかったチームに子供をので、あなたは、レイヤの右端の接合は必ずしも合致しません「キューがある空」

どのように判断することができますその後、層がそれの右端に到達しましたか?

アイデアは、それぞれのレベルに入る場合、ノードは、すべての層がエンキューされているので、この場合にすることであるLENノードforループ処理時間にlenは、)= q.size(LEN強制長さを求めますこの層では、このLENノードは、I == lenの-1を、それが最後の層は、ノードすなわちノード右端、が設けられていることを示すまで、 - >次= NULL。

ACコード:

/**
 * 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) {
        if(root==NULL)
            return;
        if(root->left==NULL && root->right==NULL)
            return;
        //层次遍历的思想,用队来存储
        queue<TreeLinkNode*>q;
        q.push(root);
        while(q.size()!=0)
        {
            int len = q.size();  //这里先取长度,然后一个for循环把该层的结点都处理了
            for(int i=0;i<len;i++) //len次 
            {
                TreeLinkNode* p = q.front();
                q.pop();
                //先解决自己的next问题
                if(i==len-1)  //这里没一次性写对。有可能有孩子,但该结点仍在右边缘!
                    p->next=NULL;
                else
                    p->next=q.front();
                
                //再入队自己的孩子
                if(p->left!=NULL)
                    q.push(p->left);
                if(p->right!=NULL)
                    q.push(p->right);
            }
            
        }
    }
};


 

おすすめ

転載: blog.csdn.net/m0_38033475/article/details/92120283