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;
}
SCAU 18923 二叉树的直径相关推荐
- LeetCode题组:第543题-二叉树的直径
1.题目 难度:简单 给定一棵二叉树,你需要计算它的直径长度.一棵二叉树的直径长度是任意两个结点路径长度中的最大值.这条路径可能穿过也可能不穿过根结点. 示例 : 给定二叉树 1/ \2 3/ \ 4 ...
- LeetCode Algorithm 543. 二叉树的直径
543. 二叉树的直径 Ideas 这题貌似也在左神算法里见过. 基本思想就是递归,根节点从左子树获得一个想要的信息,从右子树获得一个想要的信息,然后对两个信息进行处理. 其实可以把直径分成两半看:从 ...
- 二叉树的直径—leetcode543
给定一棵二叉树,你需要计算它的直径长度.一棵二叉树的直径长度是任意两个结点路径长度中的最大值.这条路径可能穿过也可能不穿过根结点. 示例 : 给定二叉树 1 / \ ...
- 543. 二叉树的直径
543. 二叉树的直径 描述 给定一棵二叉树,你需要计算它的直径长度.一棵二叉树的直径长度是任意两个结点路径长度中的最大值.这条路径可能穿过也可能不穿过根结点. 示例 : 给定二叉树 1/ \2 3/ ...
- LeetCode 543二叉树的直径-简单
给定一棵二叉树,你需要计算它的直径长度.一棵二叉树的直径长度是任意两个结点路径长度中的最大值.这条路径可能穿过也可能不穿过根结点. 示例 : 给定二叉树 1/ \2 3/ \ 4 5 返回 3, 它的 ...
- 543. 二叉树的直径 golang
文章目录 543. 二叉树的直径 example 正确解法 question 代码(wrong) 543. 二叉树的直径 概要: 借鉴了这个题的代码.可是有一个测试用例过不去 https://blog ...
- leetcode543. 二叉树的直径
给定一棵二叉树,你需要计算它的直径长度.一棵二叉树的直径长度是任意两个结点路径长度中的最大值.这条路径可能穿过根结点. 示例 : 给定二叉树 1 / \ 2 3 ...
- LeetCode 543. 二叉树的直径(DFS)
1. 题目 给定一棵二叉树,你需要计算它的直径长度.一棵二叉树的直径长度是任意两个结点路径长度中的最大值.这条路径可能穿过根结点. 示例 : 给定二叉树1/ \2 3/ \ 4 5 返回 3, 它的长 ...
- leetcode - 543. 二叉树的直径
给定一棵二叉树,你需要计算它的直径长度.一棵二叉树的直径长度是任意两个结点路径长度中的最大值.这条路径可能穿过根结点. 示例 : 给定二叉树 解题思路:使用递归,注意递归和迭代的区别 class So ...
最新文章
- 揭秘:一个月不摸鱼能写多少代码?
- NodeJS”热部署“代码,实现动态调试
- 1.Tomcat配置
- php研究所 百科_PHP活动
- 解决: Spring Boot报错 This application has no explicit mapping ... a fallback
- Milking Grid poj2185
- 知乎万赞回答:什么工具能做可视化大屏,还能做数据地图?
- 三菱fx2n64mr说明书_三菱PLC模块FX3U-64MR/DS使用手册
- SVN提交失败 Can't write to file 'E:\Repositories\xqgf\db\txn-protorevs\3616-2y4.rev':
- 285页解析百度、阿里、腾讯前端面试题,通关秘籍请收好!
- 知乎文章如何复制下来
- java使用JSON-RPC进行BTC、LTC钱包开发
- 小黑公司团建吃烤肉肉啦,mac m1死活安装不上hbase,用拯救者一下就安上啦的leetcode之旅:865. 具有所有最深节点的最小子树
- 令牌桶算法的python实现,人人都可以玩算法
- 你懂SOLID原则吗?
- 员工转正申请书_简短的员工转正申请书范文6篇
- PLSQL中Oracle设置主键自增
- 用Python语言绘制股市OBV指标效果
- Linux c 监控进程状态,linux进程监控和守护进程的程序_linux程序一实现守护进程,用于监测程序二的启动状态-C代码类资源...
- 【180928】WPF扫雷游戏源码