それを行うための再帰と議論するために、完全なバイナリツリー、優れているので、私は、この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);
}
}
}
};