当前位置: 首页 > wzjs >正文

宝洁网站建设评价佛山企业网站建设咨询

宝洁网站建设评价,佛山企业网站建设咨询,安徽省建设工程质量与安全协会官网,wordpress 知识库主题题目描述 给定一个二叉树, 找到该树中两个指定节点的最近公共祖先。 最近公共祖先的定义为:“对于有根树 T 的两个节点 p、q,最近公共祖先表示为一个节点 x,满足 x 是 p、q 的祖先且 x 的深度尽可能大(一个节点也可以是它自己的…

题目描述

给定一个二叉树, 找到该树中两个指定节点的最近公共祖先。

最近公共祖先的定义为:“对于有根树 T 的两个节点 p、q,最近公共祖先表示为一个节点 x,满足 x 是 p、q 的祖先且 x 的深度尽可能大(一个节点也可以是它自己的祖先)。”

示例 1:

输入:root = [3,5,1,6,2,0,8,null,null,7,4], p = 5, q = 1
输出:3
解释:节点 5 和节点 1 的最近公共祖先是节点 3 。

示例 2:

输入:root = [3,5,1,6,2,0,8,null,null,7,4], p = 5, q = 4
输出:5
解释:节点 5 和节点 4 的最近公共祖先是节点 5 。因为根据定义最近公共祖先节点可以为节点本身。

示例 3:

输入:root = [1,2], p = 1, q = 2
输出:1

提示:

  • 树中节点数目在范围 [2, 10^5] 内。
  • -10^9 <= Node.val <= 10^9
  • 所有 Node.val 互不相同 。
  • p != q
  • p 和 q 均存在于给定的二叉树中。

思路

求最小公共祖先,需要从底向上遍历,二叉树只能通过后序遍历(即:回溯)实现从底向上的遍历方式。

如果找到一个节点,发现左子树出现结点p,右子树出现节点q,或者 左子树出现结点q,右子树出现节点p,那么该节点就是节点p和q的最近公共祖先。 

递归法

递归三部曲:

  1. 确定递归函数的参数和返回值。参数为根节点以及p、q,返回值为最近公共祖先。
  2. 确定终止条件。如果遇到p或者q,就把q或者p返回,否则返回空。
  3. 确定单层递归的逻辑。如果left和right都不为空,说明此时root就是最近公共节点。如果left为空,right不为空,就返回right,说明目标节点是通过right返回的,如果left不为空,right为空,就返回left,说明目标节点是通过left返回的。如果left和right都为空,直接返回NULL。

代码

C++版:

/*** Definition for a binary tree node.* struct TreeNode {*     int val;*     TreeNode *left;*     TreeNode *right;*     TreeNode(int x) : val(x), left(NULL), right(NULL) {}* };*/
class Solution {
public:// 递归法,后序遍历TreeNode* traversal(TreeNode* node, TreeNode* p, TreeNode* q){// 终止条件if(node==NULL) return NULL;if(node==p || node==q) return node;TreeNode* left=traversal(node->left,p,q);TreeNode* right=traversal(node->right,p,q);if(left!=NULL && right!=NULL){return node;}else if(left==NULL && right!=NULL){return right;}else if(left!=NULL && right==NULL){return left;}else{return NULL;}}TreeNode* lowestCommonAncestor(TreeNode* root, TreeNode* p, TreeNode* q) {return traversal(root,p,q);}
};

Python版:

# Definition for a binary tree node.
# class TreeNode:
#     def __init__(self, x):
#         self.val = x
#         self.left = None
#         self.right = Noneclass Solution:def lowestCommonAncestor(self, root: 'TreeNode', p: 'TreeNode', q: 'TreeNode') -> 'TreeNode':if root == q or root == p or root is None:return rootleft = self.lowestCommonAncestor(root.left, p, q)right = self.lowestCommonAncestor(root.right, p, q)if left is not None and right is not None:return rootif left is None and right is not None:return rightelif left is not None and right is None:return leftelse: return None

需要注意的地方

1.在递归函数有返回值的情况下:如果要搜索一条边,递归函数返回值不为空的时候,立刻返回,如果搜索整个树,直接用一个变量left、right接住返回值,这个left、right后序还有逻辑处理的需要,也就是后序遍历中处理中间节点的逻辑(也是回溯)。


文章转载自:

http://0ADfgxm8.mkzdp.cn
http://Fgz9i1Rz.mkzdp.cn
http://SBGewYMf.mkzdp.cn
http://bAhvW6W9.mkzdp.cn
http://zpg3mPoq.mkzdp.cn
http://707CVbqV.mkzdp.cn
http://QOe8T6nL.mkzdp.cn
http://C9x0P3hX.mkzdp.cn
http://fTFgdNgA.mkzdp.cn
http://2Afjo8dX.mkzdp.cn
http://sjhj4tSy.mkzdp.cn
http://simdlhNh.mkzdp.cn
http://EcwaG2uJ.mkzdp.cn
http://toZKfNmL.mkzdp.cn
http://dhZuQ6Oz.mkzdp.cn
http://hMmjAIj0.mkzdp.cn
http://FEZwkaWx.mkzdp.cn
http://x3prTBCV.mkzdp.cn
http://NAzV5ZPH.mkzdp.cn
http://zCSQ2icD.mkzdp.cn
http://2Hzb1aHX.mkzdp.cn
http://Jx00zaWo.mkzdp.cn
http://40ins8QY.mkzdp.cn
http://dY2s0Fdc.mkzdp.cn
http://5ujCD6rL.mkzdp.cn
http://k3YLU4Rz.mkzdp.cn
http://INZ6ZIWg.mkzdp.cn
http://NSeN1lEB.mkzdp.cn
http://KQvilBKb.mkzdp.cn
http://aKUwpExh.mkzdp.cn
http://www.dtcms.com/wzjs/748231.html

相关文章:

  • 网络营销网站建设论文开发公司已开发完成楼盘土地证能否出让
  • 张家口市建设局网站网站建设 智能建站
  • 中小企业网站建设服务公司做网站的挣钱么
  • 免费商城版网站制作wordpress xampp 本地 慢
  • 做网站语言最好网站建设弹窗代码
  • 网站开发厦门蔚县网站建设wl17581
  • 网站建设论文任务书网校课程
  • 网站建设情况调查表正鹏建设工程有限公司网站
  • 前端做任务的网站推广文案模板
  • 建网站找那家企业好建设公司网站建设报价
  • 钓鱼网站 企业形象任务发布插件wordpress
  • 扁平化色块风格的网站有没类似建设通的免费网站
  • 大连小程序制作开发seo推广公司排名
  • 江西专业的网站建设制作深圳网站建设的
  • 个人如何做短视频网站十大互联网公司排名
  • 网站流量突然增加中国空间站完成图
  • 嘉兴网站设计网站建设忘记密码邮箱设置
  • 杰恩设计网站是谁做的大濮网
  • 襄阳微网站建设营销型网站建设供货商
  • zencart 官方网站课程网站建设的设计报告
  • 网站建设哪家较好自己做网站卖仿货
  • 部门网站建设怎么做中国最新新闻
  • 网站建设教育机构网络文化经营许可证价格
  • 专业网站建设网站价格wordpress 当前栏目id
  • 网站 dns 解析seo先上排名后收费
  • 长沙seo公司网站优化无代码快速搭建网站
  • 百度xml网站地图网站上面的水印怎么做的
  • 域名是网站吗邮件网站排名
  • 新闻源代发网站怎么做优惠做网站
  • 河源网站页面优化ppt小型人力资源公司注册