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

做网站显示不同字体中国大数据平台官网

做网站显示不同字体,中国大数据平台官网,如何使用dw制作网页,seo关键词优化教程一、题目解析 题目描述 给定两棵二叉树root和subRoot,判断root中是否存在一棵子树,其结构和节点值与subRoot完全相同。 示例说明 示例1: root [3,4,5,1,2],subRoot [4,1,2] 返回true,因为root的左子树与subRoot完…

一、题目解析

题目描述

给定两棵二叉树rootsubRoot,判断root中是否存在一棵子树,其结构和节点值与subRoot完全相同。

示例说明

  • 示例1
    root = [3,4,5,1,2]subRoot = [4,1,2]
    返回true,因为root的左子树与subRoot完全相同。

  • 示例2
    root = [3,4,5,1,2,null,null,null,null,0]subRoot = [4,1,2]
    返回false,虽然root存在节点值为4、1、2的路径,但结构与subRoot不同。

核心难点

  1. 如何高效遍历主树,找到可能与子树匹配的起始节点?
  2. 如何精确判断两棵树是否完全相同,避免结构或值的差异?

二、递归解法:深度优先搜索

核心思路

  1. 递归遍历主树:对主树的每个节点,检查以该节点为根的子树是否与目标子树相同。
  2. 递归判断子树是否相同:同时遍历两棵树的对应节点,确保结构和值完全一致。

代码实现

class Solution {public boolean isSubtree(TreeNode root, TreeNode subRoot) {return bfs(root,subRoot);}public boolean bfs(TreeNode root, TreeNode subRoot){if(root == null){return false;}return check(root,subRoot) || bfs(root.left,subRoot) || bfs(root.right,subRoot);}public boolean check(TreeNode root, TreeNode subRoot){if(root == null && subRoot == null){return true;}if(root == null || subRoot == null || root.val != subRoot.val){return false;}return check(root.left,subRoot.left) && check(root.right,subRoot.right);}
}

代码解析

  1. 主方法 isSubtree
    调用bfs方法开始递归遍历主树。

  2. 递归遍历方法 bfs

    • 终止条件:若主树为空,返回false
    • 检查当前节点:调用check方法判断以当前节点为根的子树是否与目标子树相同。
    • 递归搜索左右子树:只要在任一子树中找到匹配,立即返回true
  3. 子树比较方法 check

    • 终止条件:若两节点均为空,返回true;若仅一者为空或值不同,返回false
    • 递归比较:递归检查左右子树是否完全相同。

三、迭代解法:双端队列层序遍历

核心思路

  1. 层序遍历主树:使用双端队列按层遍历主树的每个节点。
  2. 检查子树是否相同:对每个节点,使用另一个双端队列同步比较其与目标子树的结构和值。

代码实现

class Solution {public boolean isSubtree(TreeNode root, TreeNode subRoot) {Deque<TreeNode> cur = new LinkedList<>();if (subRoot == null) return true;  if (root == null) return false;   TreeNode tempRoot = root;cur.offer(tempRoot);while(!cur.isEmpty()){tempRoot = cur.pollFirst();if(isSameTree(tempRoot,subRoot)){return true;}if(tempRoot.left != null){cur.offerFirst(tempRoot.left);}if(tempRoot.right != null){cur.offerFirst(tempRoot.right);}}return false;}public boolean isSameTree(TreeNode root, TreeNode subRoot) {Deque<TreeNode> cur = new LinkedList<>();if (root == null && subRoot == null) {return true;}TreeNode tempRoot = root;TreeNode tempSubRoot = subRoot;cur.offerFirst(tempRoot);cur.offerLast(tempSubRoot);while (!cur.isEmpty()) {tempRoot = cur.pollFirst();tempSubRoot = cur.pollLast();if (tempRoot == null && tempSubRoot == null) {continue;}if (tempRoot == null || tempSubRoot == null || tempSubRoot.val != tempRoot.val) {return false;}cur.offerFirst(tempRoot.left);cur.offerFirst(tempRoot.right);cur.offerLast(tempSubRoot.left);cur.offerLast(tempSubRoot.right);}return true;}
}

代码解析

  1. 主方法 isSubtree

    • 初始化队列:将主树根节点入队。
    • 层序遍历:每次从队列取出节点,调用isSameTree检查是否匹配。
    • 扩展队列:将当前节点的左右子节点入队,继续遍历。
  2. 子树比较方法 isSameTree

    • 双队列同步遍历:使用双端队列分别存储主树和子树的节点。
    • 节点比较:每次从队列取出两个节点,检查是否结构和值相同,并将其子节点入队。
    • 入队策略:主树节点从队首入队,子树节点从队尾入队,确保对应节点同步比较。

四、寻找匹配节点的关键逻辑

递归法

  • 遍历策略:采用前序遍历(根→左→右),确保每个节点都被检查。
  • 匹配条件:当且仅当当前节点及其所有后代与子树完全相同时,返回true

迭代法

  • 遍历策略:层序遍历(BFS),按层检查每个节点。
  • 匹配条件:使用双队列同步比较,确保每个对应节点的结构和值一致。

对比分析

方法遍历方式时间复杂度空间复杂度适用场景
递归法深度优先(DFS)O(m*n)O(max(h1,h2))树较浅,递归栈空间充足
迭代法广度优先(BFS)O(m*n)O(max(w1,w2))避免递归栈溢出

其中,m和n分别为主树和子树的节点数,h为树的高度,w为树的最大宽度。

五、常见误区与边界条件

1. 空树处理

  • 子树为空:题目规定空树是任何树的子树,因此直接返回true
  • 主树为空:若主树为空,仅当子树也为空时返回true,否则返回false

2. 结构与值的双重匹配

  • 示例:主树[1,1],子树[1]
    虽然主树存在节点值为1的子树,但结构不同(主树有两个节点),因此返回false

3. 部分路径匹配问题

  • 示例:主树[3,4,5,1,2,null,null,null,null,0],子树[4,1,2]
    主树的左子树路径为4→1→2,但2的右子节点存在0,与子树结构不符,故返回false

六、总结

核心算法思路

  1. 遍历主树:递归或迭代方式遍历每个节点。
  2. 检查子树:对每个节点,递归或迭代比较其与目标子树的结构和值。

代码优化建议

  1. 递归法:简洁直观,但可能导致栈溢出,适用于树高较小的场景。
  2. 迭代法:避免栈溢出,但代码复杂度较高,需维护双队列同步遍历。

关键技巧

  • 双队列同步遍历:确保主树和子树的对应节点被正确比较。
  • 层序遍历:通过队列按层处理节点,适合大规模数据。

理解这两种解法的核心逻辑后,可灵活应对类似的树结构匹配问题,如判断树的子结构、树的镜像等变体。

http://www.dtcms.com/wzjs/210606.html

相关文章:

  • 小说网站快速做排名如何自己编写网站
  • 网站建设用什么软件如何做好口碑营销
  • 龙口有没有做网站的网站定制的公司
  • 形象墙logo墙设计图比较好的网络优化公司
  • wordpress浏览器插件seo网络推广公司排名
  • 杭州做网站百度商品推广平台
  • 江苏省句容建设局网站seo搜索优化专员
  • 网站开发实践研究报告网络推广100种方式
  • 鞍山晟宇网站建设千锋教育前端学费多少
  • 外贸网站怎么做谷歌搜索百度推广app下载安卓版
  • 网站建设 话术如何在百度提交自己的网站
  • ui做套网站多少钱爱站网关键词查询
  • wordpress 改地址无锡优化网站排名
  • 微网站 具有哪方面的优势整合营销策略
  • 做网站的公司都缴什么税金竞价排名的服务模式是
  • 3g网站制作百度一下你就知道手机版官网
  • 网络公司网站绪论竞价托管优化公司
  • 做网站 成都域名注册局
  • 做网站logo用啥软件域名服务器ip地址查询
  • 普宁17网站一起做网店seoaoo
  • 暗网网站市场调研方案怎么写
  • 桂林尚品网络做的网站好不好谷歌浏览器下载手机版最新版
  • 搭建一个网站的具体步骤百度秒收录蜘蛛池
  • 网站备案 怎么建站seo专员简历
  • 怎么把网站做成app友情链接的形式有哪些
  • 打开上次浏览的网站模板搜索引擎推广成功的案例
  • wordpress好看的主题郑州seo关键词
  • 无锡公共工程建设中心网站seo求职信息
  • 网站建设在整体布局有哪些要求收录网站查询
  • asp.net网站伪静态网站排名优化软件