题目来源:二叉树的下一个结点_牛客题霸_牛客网 (nowcoder.com)
描述
给定一个二叉树其中的一个结点,请找出中序遍历顺序的下一个结点并且返回。注意,树中的结点不仅包含左右子结点,同时包含指向父结点的next指针。下图为一棵有9个节点的二叉树。树中从父节点指向子节点的指针用实线表示,从子节点指向父节点的用虚线表示
示例:
输入:{8,6,10,5,7,9,11},8
返回:9
解析:这个组装传入的子树根节点,其实就是整颗树,中序遍历{5,6,7,8,9,10,11},根节点8的下一个节点就是9,应该返回{9,10,11},后台只打印子树的下一个节点,所以只会打印9,如下图,其实都有指向左右孩子的指针,还有指向父节点的指针,下图没有画出来
数据范围:节点数满足 1<=n<=50,节点上的值满足 1<=val<=100.
要求:空间复杂度 ,时间复杂度
输入描述:
输入分为2段,第一段是整体的二叉树,第二段是给定二叉树节点的值,后台会将这2个参数组装为一个二叉树局部的子树传入到函数GetNext里面,用户得到的输入只有一个子树根节点
返回值描述:
返回传入的子树根节点的下一个节点,后台会打印输出这个节点.
示例1
输入:{8,6,10,5,7,9,11},8
返回值:9
我的代码:
从题目中我们可以获得每一个节点的下一个节点:8->9; 6->7; 10->11; 5->6; 7->8; 9->10; 11->nullptr.
从上面我们可以找出如下规律:
1.当该节点有右儿子时,下一个节点时右儿子的最左叶子节点。
2.当该节点没有右儿子时,如果节点是其父节点的左儿子,则下一个节点是其父节点。
如果节点不是其父节点的左儿子,则向上寻址父节点,直到是左儿子。
/*
struct TreeLinkNode {
int val;
struct TreeLinkNode *left;
struct TreeLinkNode *right;
struct TreeLinkNode *next;
TreeLinkNode(int x) :val(x), left(NULL), right(NULL), next(NULL) {
}
};
*/
class Solution {
public:
TreeLinkNode* GetNext(TreeLinkNode* pNode) {
if(pNode==nullptr)
return nullptr;
//如果有右儿子,下一个节点有事右儿子的最左子节点。
if(pNode->right){
pNode=pNode->right;
while(pNode->left){
pNode=pNode->left;
}
return pNode;
}
//如果没有右儿子,就要向上寻址父节点
while(pNode->next){
TreeLinkNode* node=pNode->next;//node是pNode的父节点
if(pNode==node->left){
return node;
}
else{
pNode=pNode->next;//继续向上寻址
}
}
return nullptr;
}
};