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

SCAU 18923 二叉树的直径

18923 二叉树的直径

Description

给定一棵二叉树,你需要计算它的直径长度。一棵二叉树的直径长度是任意两个结点路径长度中的最大值。这条路径可能穿过也可能不穿过根结点。
1
/ \
2 3
/ \
4 5
答案为3, 它的长度是路径 [4,2,1,3] 或者 [5,2,1,3]。

输入格式

共n行。
第一行一个整数n,表示有n个结点,编号为1至n。
第二行至第n行,每行有两个整数x和y,表示在二叉树中x为y的父节点。x第一次出现时y为左孩子

输出格式

输出二叉树的直径。

输入样例

5
1 2
1 3
2 4
2 5

输出样例

3

思路

使用结构体数组,用结点的数字作为下标存储该结点。
结构体中存储树结点的双亲结点及孩子结点,以及以该结点为根节点的子树的深度。

该问题可以通过比较每个子树最大的二叉树直径求解。
每个子树的最大二叉树直径,即每个子树的根节点,左子树的深度+右子树的深度。

通过比较每一个子树的最大二叉树直径,即可找到整棵树的最大二叉树直径。
A
/
B
/
… …
一个结点A的左子树深度l,可以通过该结点A的左子树的根节点B求得。
I=max(B的左子树深度,B的右子树深度)+1。
A的右子树深度r同理。
同时求出结点A的最大二叉树直径=l+r

递归的边界条件为,该结点的左/右子树为空,则该结点的左/右子树深度为0。

应从叶子结点开始计算,由题意可知输入的样例为从根结点到叶子结点的先序遍历,则使用一个数组A按输入顺序存储结点的数字(即所在结构体数组中的下标)。由后向前遍历数组A完成计算。

代码

#include <iostream>
#define For(i,a,b) for(int i=a;i<b;i++)
using namespace std;

typedef struct treenode
{
    int pn;//双亲结点所在下标
    int lchild=0;//左孩子
    int rchild=0;//右孩子
    int maxlen=1;//以该结点为根节点的子树的深度
} Tree;

Tree t[10005];

//A用于按输入顺序存储结点
int A[10005];
int main()
{
    int Ans=0,j=0;
    int n;
    cin>>n;
    For(i,1,n)
    {
        int p,c;
        cin>>p>>c;
        if(i==1)
            A[j++]=p;
        if(!t[p].lchild)//p的左孩子为空
        {
            t[c].pn=p;
            t[p].lchild=c;
        }
        else
        {
            t[c].pn=p;
            t[p].rchild=c;
        }
        A[j++]=c;

    }
    for(int i=j-1;i>=0;i--)
    {
        int l=0,r=0;
        if(t[A[i]].lchild)
          l=t[t[A[i]].lchild].maxlen;//左子树的深度
        if(t[A[i]].rchild)
          r=t[t[A[i]].rchild].maxlen;//右子树的深度
     t[A[i]].maxlen=max(l+1,r+1);//A[i]结点为根节点的子树的深度

//A[i]结点为根节点的子树的最大二叉树直径
        if(Ans<l+r)
            Ans=l+r;
    }
cout<<Ans<<endl;
return 0;
}

相关文章:

  • 关于JavaScript中整数数字不能直接调用方法
  • SCAU 发牌程序(java)
  • CSS flex布局 flex-grow不为1 items始终均匀分配剩余空间问题
  • [ HTML + CSS + Javascript ] 复盘尝试制作 2048 小游戏时遇到的问题
  • [Symbol.toPrimitive](hint) hint 什么时候为 default?
  • JavaScript 对象遍历方法及其遍历顺序的总结
  • vue 实现根据窗口大小自适应图片预览
  • 《计算机网络 自顶向下方法》笔记 - 第二章 应用层
  • 使用 BrowserRouter 报错 invaild hook call 解决方案
  • python中assert关键字的作用
  • CSS3 :nth-child(n)用法
  • CSS3中的transition属性详解
  • HTML中导航栏title前面小图标的实现
  • mysql区分大小写
  • SpringMvc中/和/*的区别
  • 【402天】跃迁之路——程序员高效学习方法论探索系列(实验阶段159-2018.03.14)...
  • 30秒的PHP代码片段(1)数组 - Array
  • C++入门教程(10):for 语句
  • Django 博客开发教程 8 - 博客文章详情页
  • JavaScript工作原理(五):深入了解WebSockets,HTTP/2和SSE,以及如何选择
  • mysql_config not found
  • SegmentFault 社区上线小程序开发频道,助力小程序开发者生态
  • 利用jquery编写加法运算验证码
  • 移动端高清、多屏适配方案
  • 整理一些计算机基础知识!
  • ​软考-高级-系统架构设计师教程(清华第2版)【第12章 信息系统架构设计理论与实践(P420~465)-思维导图】​
  • # Pytorch 中可以直接调用的Loss Functions总结:
  • # 计算机视觉入门
  • #Z2294. 打印树的直径
  • (1)(1.13) SiK无线电高级配置(六)
  • (26)4.7 字符函数和字符串函数
  • (C语言)fgets与fputs函数详解
  • (HAL)STM32F103C6T8——软件模拟I2C驱动0.96寸OLED屏幕
  • (笔试题)合法字符串
  • (强烈推荐)移动端音视频从零到上手(上)
  • (全注解开发)学习Spring-MVC的第三天
  • (十八)devops持续集成开发——使用docker安装部署jenkins流水线服务
  • (转)Oracle 9i 数据库设计指引全集(1)
  • (转)shell调试方法
  • (自适应手机端)响应式新闻博客知识类pbootcms网站模板 自媒体运营博客网站源码下载
  • ../depcomp: line 571: exec: g++: not found
  • .CSS-hover 的解释
  • .equals()到底是什么意思?
  • .Net MVC4 上传大文件,并保存表单
  • .net安装_还在用第三方安装.NET?Win10自带.NET3.5安装
  • @EnableConfigurationProperties注解使用
  • [ Linux ] git工具的基本使用(仓库的构建,提交)
  • [ vulhub漏洞复现篇 ] struts2远程代码执行漏洞 S2-005 (CVE-2010-1870)
  • [ASP]青辰网络考试管理系统NES X3.5
  • [C#]winform部署yolov9的onnx模型
  • [C++] new和delete
  • [EFI]Atermiter X99 Turbo D4 E5-2630v3电脑 Hackintosh 黑苹果efi引导文件
  • [EFI]英特尔 冥王峡谷 NUC8i7HVK 电脑 Hackintosh 黑苹果efi引导文件
  • [FFmpeg学习]从视频中获取图片
  • [hdu 3746] Cyclic Nacklace [kmp]