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

专门做音箱的网站广州seo黑帽培训

专门做音箱的网站,广州seo黑帽培训,瑞安市住房和城乡建设局网站,诸城哪里做网站原题链接🔗:二叉树的直径 难度:简单⭐️ 题目 给你一棵二叉树的根节点,返回该树的 直径 。 二叉树的 直径 是指树中任意两个节点之间最长路径的 长度 。这条路径可能经过也可能不经过根节点 root 。 两节点之间路径的 长度 由…

原题链接🔗:二叉树的直径
难度:简单⭐️

题目

给你一棵二叉树的根节点,返回该树的 直径 。

二叉树的 直径 是指树中任意两个节点之间最长路径的 长度 。这条路径可能经过也可能不经过根节点 root 。

两节点之间路径的 长度 由它们之间边数表示。

示例 1
在这里插入图片描述
输入:root = [1,2,3,4,5]
输出:3
解释:3 ,取路径 [4,2,1,3] 或 [5,2,1,3] 的长度。

示例 2

输入:root = [1,2]
输出:1

提示:

  • 树中节点数目在范围 [1, 104] 内
  • -100 <= Node.val <= 100

二叉树直径

二叉树的直径通常指的是二叉树中任意两个节点间的最长路径的长度。这个路径不一定经过根节点。二叉树的直径可以通过以下步骤求解:

  • 计算高度:首先,需要计算二叉树的高度。这可以通过递归函数实现,递归地计算左子树和右子树的高度,并返回两者中较大的一个加上当前节点的高度。

  • 更新直径:在计算高度的同时,可以更新直径。对于每个节点,其左子树的高度加上其右子树的高度就是通过该节点的路径长度,这个长度可能是当前的直径。

  • 返回结果:最终,返回记录的最大直径值。

题解

递归法

  1. 解题思路
  • 理解问题:首先,明确题目要求的“直径”是指二叉树中任意两个节点之间的最长路径长度。这个路径可以不经过根节点。

  • 递归计算高度:二叉树的高度可以通过递归计算得到。对于每个节点,其高度是其左子树和右子树高度的最大值加1。

  • 同时更新直径:在计算高度的过程中,可以同时更新直径。对于每个节点,其左子树的高度加上其右子树的高度,就是通过该节点的一条可能的最长路径长度。这个长度可能是当前的直径。

  • 使用辅助变量:由于直径的计算依赖于递归过程中的信息,因此可以使用一个辅助变量来存储遍历过程中发现的最长路径长度。

  • 遍历结束:当递归遍历完整棵树后,辅助变量中存储的就是二叉树的直径。

  • 注意边界条件:在递归函数中,如果当前节点为空,应该返回0,因为空树的高度是0。

  • 返回结果:最终,返回辅助变量中的值作为二叉树的直径。

  1. 复杂度
  • 时间复杂度:O(N),其中 N 为二叉树的节点数,即遍历一棵二叉树的时间复杂度,每个结点只被访问一次。
  • 空间复杂度:O(Height),其中 Height 为二叉树的高度。由于递归函数在递归过程中需要为每一层递归函数分配栈空间,所以这里需要额外的空间且该空间取决于递归的深度,而递归的深度显然为二叉树的高度,并且每次递归调用的函数里又只用了常数个变量,所以所需空间复杂度为 O(Height)。
  1. c++ demo
#include <iostream>
#include <algorithm>
#include <climits>
#include <queue>// 定义二叉树的节点结构
struct TreeNode {int val;TreeNode* left;TreeNode* right;TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
};// 解决方案类
class Solution {
public:// 计算二叉树的直径int diameterOfBinaryTree(TreeNode* root) {this->maxDiameter = 0; // 初始化最大直径为0calculateHeight(root); // 计算树的高度并更新最大直径return maxDiameter;}private:int maxDiameter; // 用于存储最大直径// 计算以node为根的二叉树的高度,并更新最大直径int calculateHeight(TreeNode* node) {if (!node) return 0; // 如果节点为空,返回高度0// 计算左子树和右子树的高度int leftHeight = calculateHeight(node->left);int rightHeight = calculateHeight(node->right);// 更新最大直径,如果通过当前节点的路径更长maxDiameter = std::max(maxDiameter, leftHeight + rightHeight);// 返回当前节点的高度,即左右子树高度的最大值加1return std::max(leftHeight, rightHeight) + 1;}
};// 主函数,用于测试算法
int main() {// 创建一个示例二叉树//       1//      / \//     2   3//    / \//   4   5TreeNode* 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);// 创建解决方案实例Solution solution;// 计算并输出二叉树的直径std::cout << "The diameter of the binary tree is: " << solution.diameterOfBinaryTree(root) << std::endl;// 清理分配的内存(在实际应用中应该使用智能指针来避免内存泄漏)delete root->left->left;delete root->left->right;delete root->left;delete root->right;delete root;return 0;
}
  • 输出结果:

The diameter of the binary tree is: 3
在这里插入图片描述

http://www.khdw.cn/news/16635.html

相关文章:

  • dede旅游网站模板可以免费领取会员的软件
  • 资源网站很难做百度客服平台
  • 宁波建网站推荐网站seo优化软件
  • 石家庄高端网站建设搜索引擎营销的分类
  • 商河网站建设怎么免费搭建自己的网站
  • logo设计公司怎么去跟客户谈合肥优化推广公司
  • 做网站费用联系方式seo推广网址
  • 网站制作大型公司百度论坛首页
  • wordpress3.9.x江门网站优化公司
  • 做购物网站需要学哪些营销网络的建设
  • 做视频播放网站 赚钱中央人民政府
  • 自己做的网站打开慢什么文案容易上热门
  • 网站做排名2015年网页关键词排名优化
  • 怎么去推广一个网站厦门seo公司到1火星
  • wordpress添加富强系统优化软件有哪些
  • 经三路专业做网站seo公司推荐
  • 欧美做电影 迅雷下载网站企业网
  • 怎么做电脑网站后台百度如何推广网站
  • 网站 伪静态seo站内优化站外优化
  • 在哪做网站专业国外网站建设
  • 5个常见的电子商务网站长沙seo袁飞
  • 个人网站制作体会厦门seo优化推广
  • it培训机构学费深圳seo博客
  • 十年经验网站开发公司排名优化价格
  • 响应式企业网站源码推广网页怎么做的
  • 官方网站建设 磐石网络多少费用北京seo排名收费
  • 做家簇图像网站互联网推广招聘
  • 宁德小程序开发百度首页排名优化多少钱
  • axure怎么做长页面网站网站优化推广外包
  • adobe做网站真人seo点击平台