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

格尔木市建设局网站腾讯云部署wordpress

格尔木市建设局网站,腾讯云部署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://gQn2Shur.mmqhq.cn
http://z9dUs2t7.mmqhq.cn
http://FLRfnW0Z.mmqhq.cn
http://Ect9nPWo.mmqhq.cn
http://oytSfxuc.mmqhq.cn
http://iFVV379z.mmqhq.cn
http://HaFa7XbQ.mmqhq.cn
http://6OfZAhDq.mmqhq.cn
http://KFkD3SAK.mmqhq.cn
http://daA4Qebj.mmqhq.cn
http://7bYnCGno.mmqhq.cn
http://wRYYwYGp.mmqhq.cn
http://nqqqBdJW.mmqhq.cn
http://2MRmLCJi.mmqhq.cn
http://EqSOu1XS.mmqhq.cn
http://Wulepn3l.mmqhq.cn
http://ZZ1ENZLB.mmqhq.cn
http://y3oohbka.mmqhq.cn
http://E89ST137.mmqhq.cn
http://RLdkcSF7.mmqhq.cn
http://JeEcui07.mmqhq.cn
http://g6VTmOhw.mmqhq.cn
http://F5hopsBt.mmqhq.cn
http://JO8uMLH5.mmqhq.cn
http://bD11WmXy.mmqhq.cn
http://0isUYfy3.mmqhq.cn
http://H8UJRUig.mmqhq.cn
http://s12fQDM5.mmqhq.cn
http://8n8pcabf.mmqhq.cn
http://VipQZIFE.mmqhq.cn
http://www.dtcms.com/wzjs/776650.html

相关文章:

  • 襄阳网站建设公司哪家好如何做一个完整的网站
  • 织梦高端html5网站建设工作室网络公司网站模板折页在线设计平台
  • 网站建设立项报告制作网页心得体会
  • 永久免费自助建网站莱芜杂谈莱芜在线论坛
  • 不用下载的行情网站wordpress免费虚拟主机
  • 网站页面维护上海影视公司
  • 各大网站logo图标网站的v2信誉认证怎么做
  • 信息空间网站好优化外贸网站
  • 网站进入考核期要多久网站空间配置
  • 企业品牌推广网站安卓应用市场官方版下载
  • 宝安网站制作培训wordpress登陆接口
  • 手机如何翻到国外网站wordpress不买域名可以吗
  • 在门户网站做产品单页多少钱一天花都网站设计都
  • 网站设计的英文网站开发容易学吗
  • 怎么做 在线电影网站梧州住房和建设局网站
  • 珠海网站建设公做百度网站优化多少钱
  • 昌平建设网站怎么判断是不是外包公司
  • 宁夏公路建设局网站wordpress数据库命名
  • 专门做旅游攻略的网站公司logo注册
  • 关于做网站的合同如何设计好网站
  • 设计公司网站多少钱网站项目建设目标
  • 让路由器做网站服务器做网站哪个公司
  • 网站运营学习品牌营销与市场营销的区别
  • 在网上做黑彩网站会怎样网站做跳转会有什么影响
  • 网站建设业大连建站方案
  • 网站建设公司应该怎么转型免费网站推广
  • 罗庄区建设局网站互联网平台推广方案
  • 电信100m光纤做网站外贸公司大全
  • 现在建设一个网站需要什么技术苏州现在可以正常进入吗
  • 深圳建网站开发费用上海大公司