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

室内设计专业作品集顺德搜索seo网络推广

室内设计专业作品集,顺德搜索seo网络推广,加盟做网站,建站系统做网站目录 一、二叉树理论知识 二、最小深度思路 三、完全二叉树求节点思路 四、相关算法题目 五、总结 一、二叉树理论知识 详见:代码随想录刷题day34|(二叉树篇)二叉树的递归遍历-CSDN博客 二、最小深度思路 2.1 递归法 同最大深度&…

目录

一、二叉树理论知识

二、最小深度思路

三、完全二叉树求节点思路

四、相关算法题目

五、总结


一、二叉树理论知识

详见:代码随想录刷题day34|(二叉树篇)二叉树的递归遍历-CSDN博客

二、最小深度思路

2.1 递归法

同最大深度,不同点在于,求最小深度时,要单独处理,左子树不为空或者右子树不为空的情况,否则容易出错;(五总结里的错误

2.2 迭代法

详见:代码随想录刷题day38|(二叉树篇)二叉树的层序遍历(429、515、116、117、104、111)-CSDN博客

三、完全二叉树求节点思路

基于完全二叉树的特性:借助满二叉树

满二叉树是一种特殊的二叉树,其中每一层的节点数都达到了可能的最大值。这意味着在满二叉树中,除了叶子节点外,每个节点都有两个子节点。满二叉树的高度为h,那么它的节点总数将是2^{h} - 1

如果一棵树是满二叉树,那么求出深度n后,满二叉树的节点数= 2^{n} -1

 故:首先判断一棵子树是否为满二叉树,如果是,根据深度求出节点数返回给上一层节点,如果不是,继续向下遍历,找出满二叉树(注:单个节点是满二叉树);最后根节点根据左子树数量+右子树数量+1,即为完全二叉树的节点个数;

如何判断是否为满二叉树:在完全二叉树的基础上,从某子树的根节点开始向左遍历的深度 = 向右遍历的深度;即为满二叉树,同时深度也已求出;

四、相关算法题目

111.二叉树的最小深度

class Solution {public int minDepth(TreeNode root) {//递归法return getHight(root);}public int getHight(TreeNode node){if(node == null){return 0;}else if(node.left == null && node.right == null){return 1;}else if(node.left == null && node.right != null){return 1 + getHight(node.right);}else if(node.left != null && node.right == null){return 1 + getHight(node.left);}else{int leftHight = getHight(node.left);int rightHight = getHight(node.right);int hight = Math.min(leftHight, rightHight);return 1 + hight;}}
}

222.完全二叉树的节点个数

 递归法

class Solution {public int countNodes(TreeNode root) {//递归法return getNum(root);}public int getNum(TreeNode node){if(node == null) return 0;int leftNum = getNum(node.left);int rightNum = getNum(node.right); //getNum(node.left);//getNum(node.right);return 1 + leftNum + rightNum;}
}

迭代法:层序遍历

class Solution {public int countNodes(TreeNode root) {//层序遍历 队列统计 按照普通二叉树的求法之迭代法Deque<TreeNode> deque = new ArrayDeque<>();if(root == null) return 0;deque.offer(root);int count = 0;while(!deque.isEmpty()){TreeNode node = deque.poll();count++;if(node.left != null) deque.offer(node.left);if(node.right != null) deque.offer(node.right);}return count;}
}

完全二叉树特性

class Solution {public int countNodes(TreeNode root) {//完全二叉树特性return getNum(root);}public int getNum(TreeNode node){if(node == null) return 0;TreeNode leftNode = node.left;TreeNode rightNode = node.right;int leftDepth = 0;int rightDepth = 0;while(leftNode != null){//遍历左侧的深度leftNode = leftNode.left;leftDepth++;}while(rightNode != null){//遍历右侧的深度rightNode = rightNode.right;rightDepth++;}if(leftDepth == rightDepth){//说明是满二叉树return (2 << leftDepth) - 1; // 注意(2<<1) 相当于2^2,所以leftDepth初始为0}else{int left = getNum(node.left);int right = getNum(node.right);return 1 + left + right;}}
}

 五、总结

1.错误代码:当前代码的逻辑是直接取左右子树的最小深度加 1,但这种逻辑在某些情况下会出错。

class Solution {public int minDepth(TreeNode root) {//递归法return getHight(root);}public int getHight(TreeNode node){if(node == null) return 0;int leftHight = getHight(node.left);int rightHight = getHight(node.right);int hight = Math.min(leftHight, rightHight);return 1 + hight;}
}

错误原因:如果某个子树为空,这条路径不应该被考虑。所以应该分情况讨论

2. (2 << leftDepth) - 1

  • 2 << leftDepth 是位运算,等价于 2 * (2^leftDepth),即 2^(leftDepth + 1)

  • (2 << leftDepth) - 1 就是 2^(leftDepth + 1) - 1,即满二叉树的节点总数。

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

相关文章:

  • 如何写网站代码是什么原因网站广告调词平台
  • fullpage wow做的网站产品营销软文
  • 长沙网站优化外包外链推广网站
  • 北滘网站设计西安seo网站建设
  • 做网站的被拘留了网络营销推广方案整合
  • 类似qq空间的网站拼多多seo怎么优化
  • 东莞土木建筑学会网站广州竞价外包
  • 在线商城网站模板上海百度推广开户
  • 博山政府网站建设哪家专业百度品牌广告
  • 网站的软文 怎么做推广网络推广外包公司排名
  • 潜江网站开发seo指导
  • 网站建设业务员沟通需求专业做网站公司
  • 制作卖东西网站seo排名快速
  • 熊掌号做网站推广的注意事项网络营销方案
  • 温州排名推广优化神马排名软件
  • 简历旅游网站开发经验百度pc网页版入口
  • asp.net网站开发pdf企业做推广有用吗
  • 网站建设_你真的懂吗?爱站网关键词密度查询
  • 模板网站制作多少钱怎么弄一个自己的网站
  • 做设计必看十大网站长沙网站推广和优化
  • 网站建设过程报告seo如何建立优化网站
  • 房地产建筑公司网站推广网站软文
  • 福田做商城网站建设哪家公司靠谱优化网站排名需要多少钱
  • 教育局建设网站的必要性试分析网站推广和优化的原因
  • 广州网站开发小程序百度推广代理公司
  • 湖州品牌网站设计搜索引擎优化方案案例
  • 兰州城建设计院网站南京百度快照优化排名
  • 网站logo的颜色与网页的颜色seo公司彼亿营销
  • 做设计适合关注的网站简短的营销软文范文
  • 日本真人做a视频网站佛山网站建设解决方案