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;
}

SCAU 18923 二叉树的直径相关推荐

  1. LeetCode题组:第543题-二叉树的直径

    1.题目 难度:简单 给定一棵二叉树,你需要计算它的直径长度.一棵二叉树的直径长度是任意两个结点路径长度中的最大值.这条路径可能穿过也可能不穿过根结点. 示例 : 给定二叉树 1/ \2 3/ \ 4 ...

  2. LeetCode Algorithm 543. 二叉树的直径

    543. 二叉树的直径 Ideas 这题貌似也在左神算法里见过. 基本思想就是递归,根节点从左子树获得一个想要的信息,从右子树获得一个想要的信息,然后对两个信息进行处理. 其实可以把直径分成两半看:从 ...

  3. 二叉树的直径—leetcode543

    给定一棵二叉树,你需要计算它的直径长度.一棵二叉树的直径长度是任意两个结点路径长度中的最大值.这条路径可能穿过也可能不穿过根结点. 示例 : 给定二叉树 1          / \         ...

  4. 543. 二叉树的直径

    543. 二叉树的直径 描述 给定一棵二叉树,你需要计算它的直径长度.一棵二叉树的直径长度是任意两个结点路径长度中的最大值.这条路径可能穿过也可能不穿过根结点. 示例 : 给定二叉树 1/ \2 3/ ...

  5. LeetCode 543二叉树的直径-简单

    给定一棵二叉树,你需要计算它的直径长度.一棵二叉树的直径长度是任意两个结点路径长度中的最大值.这条路径可能穿过也可能不穿过根结点. 示例 : 给定二叉树 1/ \2 3/ \ 4 5 返回 3, 它的 ...

  6. 543. 二叉树的直径 golang

    文章目录 543. 二叉树的直径 example 正确解法 question 代码(wrong) 543. 二叉树的直径 概要: 借鉴了这个题的代码.可是有一个测试用例过不去 https://blog ...

  7. leetcode543. 二叉树的直径

    给定一棵二叉树,你需要计算它的直径长度.一棵二叉树的直径长度是任意两个结点路径长度中的最大值.这条路径可能穿过根结点. 示例 : 给定二叉树 1          / \         2   3 ...

  8. LeetCode 543. 二叉树的直径(DFS)

    1. 题目 给定一棵二叉树,你需要计算它的直径长度.一棵二叉树的直径长度是任意两个结点路径长度中的最大值.这条路径可能穿过根结点. 示例 : 给定二叉树1/ \2 3/ \ 4 5 返回 3, 它的长 ...

  9. leetcode - 543. 二叉树的直径

    给定一棵二叉树,你需要计算它的直径长度.一棵二叉树的直径长度是任意两个结点路径长度中的最大值.这条路径可能穿过根结点. 示例 : 给定二叉树 解题思路:使用递归,注意递归和迭代的区别 class So ...

最新文章

  1. 揭秘:一个月不摸鱼能写多少代码?
  2. NodeJS”热部署“代码,实现动态调试
  3. 1.Tomcat配置
  4. php研究所 百科_PHP活动
  5. 解决: Spring Boot报错 This application has no explicit mapping ... a fallback
  6. Milking Grid poj2185
  7. 知乎万赞回答:什么工具能做可视化大屏,还能做数据地图?
  8. 三菱fx2n64mr说明书_三菱PLC模块FX3U-64MR/DS使用手册
  9. SVN提交失败 Can't write to file 'E:\Repositories\xqgf\db\txn-protorevs\3616-2y4.rev':
  10. 285页解析百度、阿里、腾讯前端面试题,通关秘籍请收好!
  11. 知乎文章如何复制下来
  12. java使用JSON-RPC进行BTC、LTC钱包开发
  13. 小黑公司团建吃烤肉肉啦,mac m1死活安装不上hbase,用拯救者一下就安上啦的leetcode之旅:865. 具有所有最深节点的最小子树
  14. 令牌桶算法的python实现,人人都可以玩算法
  15. 你懂SOLID原则吗?
  16. 员工转正申请书_简短的员工转正申请书范文6篇
  17. PLSQL中Oracle设置主键自增
  18. 用Python语言绘制股市OBV指标效果
  19. Linux c 监控进程状态,linux进程监控和守护进程的程序_linux程序一实现守护进程,用于监测程序二的启动状态-C代码类资源...
  20. 【180928】WPF扫雷游戏源码

热门文章

  1. 猜数字游戏实现(详解)
  2. SpringCloud Gateway获取post请求体(request body)
  3. 算法之深度优先搜素(DFS)和广度优先搜素(BFS)
  4. 爱立信忙收5G专利费;中兴助力LPWAN物联网商用| IoT黑板报
  5. windows如何删除管理员权限的文件夹
  6. 微信下载app(转载)
  7. 欧美商务画册风公司介绍
  8. 如何实现模拟量信号远距离无线传输?
  9. 电源、信号完整性与高速电路
  10. 正则表达式 多个手机号之间使用英文逗号分隔