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

校园门户网站建设实施方案营销网站建设

校园门户网站建设实施方案,营销网站建设,网站优化建设南昌,郑州制作网站哪家好文章目录翻转二叉树对称二叉树二叉树的最大深度二叉树的最小深度翻转二叉树 题目链接:226. 翻转二叉树 解题逻辑: 翻转二叉树也就是将所有非叶节点的左右孩子相互交换,那么我们就可以采用层序遍历判断非叶节点进行翻转: 初始化一…

文章目录

  • 翻转二叉树
  • 对称二叉树
  • 二叉树的最大深度
  • 二叉树的最小深度

翻转二叉树

题目链接:226. 翻转二叉树

解题逻辑:

翻转二叉树也就是将所有非叶节点的左右孩子相互交换,那么我们就可以采用层序遍历判断非叶节点进行翻转:

  • 初始化一个辅助队列
  • 将根节点添加到队列中去
  • 弹出队头元素
  • 如果该元素的两个子节点均不为null则翻转两个子节点
  • 然后将子节点入队
  • 如此循环往复直到队列为空

代码如下:

class Solution {public TreeNode invertTree(TreeNode root) {Deque<TreeNode> que = new ArrayDeque<>();if(root == null) return null;que.add(root);while(!que.isEmpty()) {TreeNode item = que.remove();if(item.left == null && item.right == null) continue;TreeNode temp = item.left;item.left = item.right;item.right = temp;if(item.right != null) que.add(item.right);if(item.left != null) que.add(item.left);}return root;}
}

对称二叉树

题目链接:101. 对称二叉树

解题逻辑:

在这里插入图片描述

如果二叉树对称的话那么左右子树一定满足上图中的内相同、外相同。接下来要选择一种遍历方式,这种遍历方式要满足一个条件,能得到内相同,外相同的结果。唯一满足的方式就是后序遍历,因为后序遍历的顺序是左右中,中处在左右之后,是可以拿到左右判断的结果的。

接下来围绕递归的三要素完善一下细节:

  • 确认传入参数以及返回值:返回值是boolean,也就代表是否对称。传入参数是两个比较的节点
  • 确认递归出口:
    • 根据传入方法的两个结点的情况,可以考虑到以下三种情况
    • null 非空:返回false
    • 非空 null:返回false
    • null null:返回true
    • 非空 非空,但是值不相同:返回false
  • 确认单层的逻辑:
    • 判断是否外相同:左节点的左孩子和右节点的右孩子是否相同
    • 判断是否内相同:左节点的右孩子和右节点的左孩子是否相同
    • 只有当上面两个条件都满足才能返回true

代码如下:

class Solution {public boolean isSymmetric(TreeNode root) {return compareNode(root.left,root.right);}public boolean compareNode(TreeNode left,TreeNode right){if(left == null && right != null) return false;else if(left != null && right == null) return false;else if(left == null && right == null) return true;else if(left != null && right != null && left.val != right.val) return false;boolean result1 = compareNode(left.left,right.right);boolean result2 = compareNode(left.right,right.left);return result1 && result2;}
}

二叉树的最大深度

题目链接:104. 二叉树的最大深度

解题思路:

首先我们要了解二叉树的两个重要概念:

  • 节点深度:指从根节点到该节点的最长简单路径边的条数或者节点数(取决于深度从0开始还是从1开始)
  • 节点高度:指从该节点到叶子节点的最长简单路径边的条数或者节点数(取决于高度从0开始还是从1开始)

节点深度我们是从上往下统计,节点高度是从下往上统计。而二叉树的最大深度就等于二叉树的根节点高度。所以我们可以通过求根节点高度来求最大深度。而如果直接求最大深度的话涉及回溯算法,在后面会系统学习,此处先不做要求。

这一题仍然也是涉及到了递归遍历,接下来我们还是从递归三元素来分析:

  • 参数以及返回值:获得根节点高度,参数只需要传入节点即可,而返回值就是int,表示当前节点的高度,
  • 递归出口:递归到null节点,直接返回0
  • 单层逻辑:使用后序遍历,从而可以拿到两个子节点的高度,而当前节点的高度就是两者的较大值 + 1

代码如下:

class Solution {public int maxDepth(TreeNode root) {return getHeight(root);}public int getHeight(TreeNode node){if(node == null) return 0;int height1 = getHeight(node.left);int height2 = getHeight(node.right);return Math.max(height1, height2) + 1;}
}

二叉树的最小深度

题目链接:111. 二叉树的最小深度

解题思路:

这一题与上一题差不多,也是通过高度去求深度。但是如果只是将取最大值修改为取最小值是不对的,因为最小深度的定义是从根节点到最近叶子节点的最短路径上的节点数量,没有叶子节点的路径是不考虑的。所以我们还需要添加一点逻辑:

  • 当该节点的只存在左孩子节点没有右孩子节点,那么最小高度按左孩子算
  • 当该节点的只存在右孩子节点没有左孩子节点,那么最小高度按右孩子算
class Solution {public int minDepth(TreeNode root) {return getHeight(root);}public int getHeight(TreeNode node){if(node == null) return 0;int height1 = getHeight(node.left);int height2 = getHeight(node.right);if(height1 == 0 && height2 != 0) return height2 + 1;else if(height1 != 0 && height2 == 0) return height1 + 1;return Math.min(height1, height2) + 1;}
}
http://www.dtcms.com/wzjs/565765.html

相关文章:

  • 网站icp备案 技术负责人修水网站建设
  • 吉林省建设集团网站企业邮箱注册申请入口
  • 免费软件app下载大全正能量网站seo网站优化培训怎么样
  • 专业做网站建设公上海网站建设开
  • 宁德城乡住房建设厅网站wordpress评论已关闭
  • 个人网站设计师wordpress手动裁剪
  • 网站体验分享官方网站建设实训心得
  • 杭州网站建设(推荐乐云践新)搭建个人博客wordpress
  • 深圳工信部网站备案信息查询如何登录linux wordpress
  • 深圳住房和建设局网站哪里预约公司企业官网建设价格
  • 中国城乡建设部网站证书查询上海企业建设网站服务
  • 网店网页制作工具抖音seo工具
  • 厦门网站设计个人网站开发预留接口
  • 低价建设手机网站现在网站开发用什么
  • 网站布局方案福建省建设工程继续教育网站
  • 锤子 网站 模版暴雪回归
  • 企业如何应用网站的wordpress添加数据库文件
  • 网站备案查询不到模版网站系统
  • 做婚庆网站图片下载网站的营销推广方案及预算
  • 做网彩网站做二手家电市场加什么网站可以
  • 河北手机网站制作多少钱国内最新新闻事件摘抄
  • 淄博网站建设公司有多少家网站建设的工具是
  • 网站建设优化项目腾讯邮箱注册
  • 宁波做网站有哪些公司公司专业网站建设方案
  • 做网站 设计师很ui设计要学几个软件
  • 临西县建设网站wordpress手机号
  • 网站备案 取名资讯通不过开发软件的应用
  • 网站管理是什么工作西安官网排名推广
  • 企业做网站上海河北手机响应式网站建设设计
  • 遵义网站建设网帮你网络运营培训