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

新发布一个网站公告怎么做新东方烹饪学校学费价目表

新发布一个网站公告怎么做,新东方烹饪学校学费价目表,做项目网站要不要备案,长沙加度网络科技有限公司原题链接🔗:二叉树的直径 难度:简单⭐️ 题目 给你一棵二叉树的根节点,返回该树的 直径 。 二叉树的 直径 是指树中任意两个节点之间最长路径的 长度 。这条路径可能经过也可能不经过根节点 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.wangmingla.cn/news/63866.html

相关文章:

  • 和男朋友都是第一次做网站网上接单平台有哪些
  • 网站开发平台景德镇seo
  • 专门做微信推送的网站优化大师软件下载
  • 注册商标怎么注册商标关键词优化公司如何选择
  • sketch做网站线框图快速学电脑培训班
  • 个人做网站有什么坏处网络营销策划方案3000字
  • 如何做网站的网页怎样做app推广
  • 做电子商务系统网站建设seo工具软件
  • 政府网站集约化平台建设方案网址链接生成器
  • 企业网站建设设计服务地推公司排名
  • 店铺设计风格有哪些珠海关键词优化软件
  • 如何夸奖一个网站做的好广告网站留电话
  • 中小型网站设计哪家好怎么自己刷推广链接
  • 怎么看网站有没有做竞价哈尔滨优化调整人员流动管理
  • 网站代做多长时间杭州网络整合营销公司
  • 商派商城网站建设公司seo优化师就业前景
  • 网站反连接湖南靠谱seo优化
  • 河南南阳最新消息今天seo算法优化
  • 沈阳市人大网站建设时间网络营销渠道有哪些
  • 做电商要有网站吗自己怎么搭建网站
  • 做网站mfdos怎么创建个人网站
  • 中国做外贸网站有哪些问题承德seo
  • 深圳网站建设jm3q品牌如何推广
  • 网站未备案wordpress链接南宁推广公司
  • 建设门户网站申请免费软文推广平台都有哪些
  • sq网站推广怎么建网站平台卖东西
  • 物流营销型网站案例分析百度搜索推广登录入口
  • 如何编辑做网站网络销售推广公司
  • 做网站的公司有哪些产品50个关键词
  • 网站上的vR场景贴图怎么做的seo关键词挖掘