标签:TreeNode 一个 fatherP nullptr father 二叉树 节点
二叉树的下一个节点给定一棵二叉树的其中一个节点,请找出中序遍历序列的下一个节点。
注意:
- 如果给定的节点是中序遍历序列的最后一个,则返回空节点;
- 二叉树一定不为空,且给定的节点一定不是空节点;
数据范围
树中节点数量 [0,100]。
样例
假定二叉树是:[2, 1, 3, null, null, null, null], 给出的是值等于2的节点。
则应返回值等于3的节点。
解释:该二叉树的结构如下,2的后继节点是3。
2
/ \
1 3
解题思路见注释:
1 /** 2 * Definition for a binary tree node. 3 * struct TreeNode { 4 * int val; 5 * TreeNode *left; 6 * TreeNode *right; 7 * TreeNode *father; 8 * TreeNode(int x) : val(x), left(NULL), right(NULL), father(NULL) {} 9 * }; 10 */ 11 class Solution { 12 public: 13 TreeNode* inorderSuccessor(TreeNode* p) { 14 if (p == nullptr) { 15 return nullptr; 16 } 17 TreeNode *pNext = nullptr; 18 // 如果当前节点的右节点不为空,则当前节点的下一个节点为当前节点的右节点的最左节点 19 if (p->right != nullptr) { 20 TreeNode *pRight = p->right; 21 while (pRight->left != nullptr) { 22 pRight = pRight->left; 23 } 24 pNext = pRight; 25 } else if (p->father != nullptr) { // 当前结点无右子树,则需要找到一个是它父结点的左子树结点的结点 26 // 当前节点 27 TreeNode *curNode = p; 28 // 当前节点的父节点 29 TreeNode *fatherP = p->father; 30 while (fatherP != nullptr && curNode == fatherP->right) { 31 curNode = fatherP; 32 fatherP = curNode->father; 33 } 34 pNext = fatherP; 35 } 36 return pNext; 37 } 38 };
标签:TreeNode,一个,fatherP,nullptr,father,二叉树,节点 来源: https://www.cnblogs.com/MGFangel/p/16154856.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。