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

做网站页面如何在百度发布文章

做网站页面,如何在百度发布文章,网站 服务器 带宽 估算 网站流量,网页建立网站平台Hello,大家好,我是阿月!坚持刷题,老年痴呆追不上我,今天刷:完全二叉树的节点个数 题目 222.完全二叉树的节点个数 代码实现 class TreeNode {int val;TreeNode left, right;public TreeNode(int val) …

Hello,大家好,我是阿月!坚持刷题,老年痴呆追不上我,今天刷:完全二叉树的节点个数

题目

222.完全二叉树的节点个数
在这里插入图片描述

代码实现

class TreeNode {int val;TreeNode left, right;public TreeNode(int val) {this.val = val;this.left = this.right = null;}
}public class CompleteBinaryTreeCount {// 计算完全二叉树的节点个数public int countNodes(TreeNode root) {if (root == null) {return 0;}int leftHeight = leftHeight(root);int rightHeight = rightHeight(root);if (leftHeight == rightHeight) {// 左子树是满二叉树return (1 << leftHeight) - 1;} else {// 左子树不是满二叉树,递归计算左右子树的节点数return 1 + countNodes(root.left) + countNodes(root.right);}}// 计算左子树的高度private int leftHeight(TreeNode root) {int height = 0;while (root != null) {height++;root = root.left;}return height;}// 计算右子树的高度private int rightHeight(TreeNode root) {int height = 0;while (root != null) {height++;root = root.right;}return height;}public static void main(String[] args) {// 创建一个完全二叉树示例TreeNode root = new TreeNode(1);root.left = new TreeNode(2);root.right = new TreeNode(3);root.left.left = new TreeNode(4);root.left.right = new TreeNode(5);root.right.left = new TreeNode(6);CompleteBinaryTreeCount solution = new CompleteBinaryTreeCount();int nodeCount = solution.countNodes(root);System.out.println("完全二叉树的节点个数: " + nodeCount);}
}

实现总结

  • 完全二叉树:完全二叉树的定义是除了最后一层外,其它各层的节点数都达到最大值,且最后一层的节点依次从左到右排列。这一特性对计算节点数有重要影响。
  • 确定解题方法:常见的方法包括递归和迭代。在了解完全二叉树的性质后,可以选择合适的方法求解节点数,上面实现就采用了递归的方式实现。
  • 确定节点数计算方式:针对完全二叉树的特性,可以通过一些方法,如树的高度、子树的特性等来计算节点数。上面实现通过计算左子树和右子树的高度来确定完全二叉树的结构,如果左右子树高度相等,则左子树是满二叉树,节点个数可以通过2的幂次方计算。如果左右子树高度不等,则递归计算左右子树的节点数。
  • 考虑边界情况:对于空树或者只有根节点的情况,需要特殊处理。
  • 时间复杂度O(log^2 N)。递归的深度为树的高度,每次递归中需要计算左右子树的高度,因此时间复杂度为 O(log N),其中 N 为节点个数。在每层递归中,都需要进行一次高度计算,高度计算的时间复杂度也为 O(log N),因此总体时间复杂度为 O(log^2 N)
http://www.mmbaike.com/news/87442.html

相关文章:

  • 百度推广移动端网站查询网址域名
  • 哪里有做网站优化的公司百度搜索引擎优化的养成良好心态
  • 如何的找网站建设公司爱站网关键词长尾挖掘
  • 广州家具网站建设杭州seo平台
  • 企业做网站的合同公司网站设计的内容有哪些
  • thinkphp相比Wordpress海淀区seo搜索优化
  • 哪些网站可以做旅游关键词优化的最佳方法
  • 北仑网站建设wordpress
  • 修仙网页游戏大全seo黑帽教程视频
  • 网站续费怎么做帐关键词密度
  • 河南省建筑市场一体化平台宁德seo培训
  • 鞍山新款网站制作哪家好西安seo顾问公司
  • ftp上传网站之后seo基础入门免费教程
  • 网站设计标准字体推广app赚佣金平台有哪些
  • 百度推广哪个公司好怎么做关键词优化排名
  • 网站建设属于什么经营范围百度优化推广
  • 免费做电子目录的网站什么是关键词
  • 免费ftp转换wordpressseo课程培训班费用
  • 一流的邯郸网站建设厦门seo关键词优化培训
  • 帮做ppt网站站长工具忘忧草
  • 网站开发经验与教训软文代写发布
  • 南阳建网站公司想做个网站怎么办
  • 福州高端网站建设网站制作多少钱
  • 新注册的公司怎么做网站友情链接管理系统
  • 西安互联网公司seo点击排名工具有用吗
  • 阿坝州网站制作十句经典广告语
  • 动态网站订单怎么做整合营销传播的方法包括
  • 电子科技网站北京seo网站设计
  • 哪些网站可以接设计的单子做哈尔滨网络优化公司有哪些
  • 广东 网站建设最新的销售平台