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

关于水果的网站建设网站建设策划书目录

关于水果的网站建设,网站建设策划书目录,建设网站需要下载神呢软件吗,移动端h5网站开发框架原题链接🔗:二叉树的直径 难度:简单⭐️ 题目 给你一棵二叉树的根节点,返回该树的 直径 。 二叉树的 直径 是指树中任意两个节点之间最长路径的 长度 。这条路径可能经过也可能不经过根节点 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.yayakq.cn/news/41420/

相关文章:

  • 太原市住房和城乡建设厅网站西安seo服务公司排名
  • 海外营销网站51wordpress
  • wordpress数据搬移七台河网站seo
  • 中华企业网站建设wordpress删除主题
  • 网站开发需要的资源建设网站运营收入
  • 胖哥网站的建设目标白城哪家做网站
  • 建设企业网站一般多少钱外贸销售工作内容
  • 常州天狼网站建设用电脑建立网站
  • 郑州网站营销推广网易企业邮箱域名是什么
  • 淄博做网站的公司健康中国app
  • 网站编程设计如何写备注网页制作与网站建设填空题
  • 网站返回500错误页面wordpress 栏目 伪静态
  • 北京网站建设 优化哪里有建设哪里有我们
  • 河南中国建设厅官方网站贵阳做网站公司吗
  • 中企动力的网站营销型网站建设策划书怎么写
  • 专做商业平台网站网站百度收录秒收方法
  • 引用网站代码兰州app定制开发
  • 多语言网站seo网络口碑营销的特点
  • 如何填写网站建设计划表cms系统和网站后台系统
  • 北京网站seo推广北京网站建设公司哪家最好
  • 网站开发课设心得网站开发树形图
  • 移动网站源码单页销售网站制作制作
  • 有什么网站可以做充值任务网站建设基础大纲文案
  • 盐城市住房城乡建设网站企业所得税怎么算2020
  • 柳州住房和城乡建设局网站网站建设行业资讯
  • 高效简便的网站开发如何在百度上搜到网站
  • 站长工具 站长之家做商城网站要什么证件
  • 长沙竞价网站建设报价寿县移动公司网站建设
  • 长春火车站在哪个街道招聘网站套餐费用怎么做分录
  • 公司网页制作网站上海手机网站建设公司