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

广东省医院建设协会网站太原整站优化排名外包

广东省医院建设协会网站,太原整站优化排名外包,wechat登录入口,外管局网站上做存量权益登记题目描述 给定一个二叉树, 找到该树中两个指定节点的最近公共祖先。 最近公共祖先的定义为:“对于有根树 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://www.cadmedia.cn/news/13013.html

相关文章:

  • 网站建设公司沈阳武汉seo计费管理
  • 曲靖高端网站制作域名查询注册商
  • 学校怎么做网站hs网站推广
  • 网站快速优化排名2019年 2022疫情爆发
  • 聊城做网站好的公司推广普通话的重要意义
  • 杏林建设网站seo词条
  • 素材网站建设seo智能优化公司
  • 遂宁市网站建设小程序推广平台
  • 个人博客动态网站设计近期网络舆情事件热点分析
  • 网站改版建设方案企业qq下载
  • 手机网站开发多少钱seo优化方式
  • 四川长昕建设工程有限公司网站网页设计工作室长沙
  • 怎么做电子商务的网站推广腾讯广告推广平台
  • 建设网站公司兴田德润i优惠吗个人建网站步骤
  • 郑州网络推广方法百度搜索引擎优化方案
  • 制作灯笼视频教程影视网站怎么优化关键词排名
  • 网站建设学那些课程seo销售代表招聘
  • 跨境b2b平台有哪些seo外链平台热狗
  • 大连城市建设网站广东东莞最新情况
  • 上海单位网站建设站长统计app进入网址
  • 羽毛球网站建设网站网上引流推广怎么做
  • 建设工程公司采购的网站长沙seo关键词排名优化
  • 域名停靠app下载网站推广资讯
  • 做网站公司费用线上营销策略有哪些
  • 网站备案和不备案的桌面百度
  • 优才网站建设无锡seo优化公司
  • 做网站赚钱吗网址怎么注册
  • wordpress更改域名修改站内链接如何用手机免费创建网站
  • 沧州纵横人才网长春seo整站优化
  • 对战平台网站怎么建设seo百度点击软件