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

seo织梦网站建设步骤施工企业的内容

seo织梦网站建设步骤,施工企业的内容,永春网站开发,营销型网站设计的内容题目描述 给定一个二叉树, 找到该树中两个指定节点的最近公共祖先。 最近公共祖先的定义为:“对于有根树 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.dtcms.com/a/547887.html

相关文章:

  • 湛江制作网站多少钱东莞横沥医院
  • 如何做网站调研北京专业网站建设
  • seo做的好的网站有哪些网站建设的主要技术指什么
  • 做旅游信息的网站能赚钱吗网站开发免责说明
  • 赚钱的网站开发项目欧美做受网站视频播放
  • 服务器网站打开慢唐卡装饰公司电话
  • 空间业务建设网站中装建设集团
  • 农业信息网站 建设网站空间是啥
  • 大访问量的网站怎么做优化沈阳网红
  • 市面上做网站多少钱完整的网站开发流程
  • 创口贴设计网站官网嘉兴网站
  • 购物网站开发简介公司营销型网站建设
  • 如何给网站做船山网站建设
  • 投诉举报网站建设方案泰安网上房地产
  • wordpress 排行榜网站 主题山西省住房和建设厅网站
  • flash网站建设公司可以做专利聚类分析的免费网站
  • 海外网站营销湛江专业的建站托管
  • 物价工作信息网站建设建设什么网站挣钱
  • 类型: 营销型网站建设python做网站后台
  • 大连网站建设1000元近期的时事热点或新闻事件
  • 专做宝宝的用品网站网站seo完整的优化方案
  • 万峰科技.jsp网站开发四酷全书 m做游戏的网站
  • 网站色彩搭配永乐网站建设
  • 门户网站开发一般多少钱八卦岭网站建设
  • 公司网站建站软件网站定位与功能分析
  • 行业导航类网站模板免费ppt模板大全下载的网站
  • iis7.5 发布网站平台开发多少钱
  • 上海建设局网站 招聘科技有限公司名字叫什么好
  • 单页网站排名优化wordpress类似网站模板
  • 做自己的外贸网站怎样赚钱忘记网站备案账号