p1501 二叉树最大宽度和高度
2015-08-03 10:58
176 查看
题目描述 Description
给出一个二叉树,输出它的最大宽度和高度。
输入描述 Input Description
第一行一个整数n。
下面n行每行有两个数,对于第i行的两个数,代表编号为i的节点所连接的两个左右儿子的编号。如果没有某个儿子为空,则为0。
输出描述 Output Description
输出共一行,输出二叉树的最大宽度和高度,用一个空格隔开。
样例输入 Sample Input
5
2 3
4 5
0 0
0 0
0 0
样例输出 Sample Output
2 3
数据范围及提示 Data Size & Hint
n<16
默认第一个是根节点
以输入的次序为编号
2-N+1行指的是这个节点的左孩子和右孩子
注意:第二题有极端数据!
1
0 0
这题你们别想投机取巧了,给我老老实实搜索!
给出一个二叉树,输出它的最大宽度和高度。
输入描述 Input Description
第一行一个整数n。
下面n行每行有两个数,对于第i行的两个数,代表编号为i的节点所连接的两个左右儿子的编号。如果没有某个儿子为空,则为0。
输出描述 Output Description
输出共一行,输出二叉树的最大宽度和高度,用一个空格隔开。
样例输入 Sample Input
5
2 3
4 5
0 0
0 0
0 0
样例输出 Sample Output
2 3
数据范围及提示 Data Size & Hint
n<16
默认第一个是根节点
以输入的次序为编号
2-N+1行指的是这个节点的左孩子和右孩子
注意:第二题有极端数据!
1
0 0
这题你们别想投机取巧了,给我老老实实搜索!
#include<iostream> using namespace std; struct treetype{ int l,r; }; int height[16]={0},weight[16]={0},maxheight=0,maxweight=0; treetype tree[16]; void search(int x) { if (height[x]>maxheight) maxheight=height[x]; if (weight[height[x]]>maxweight) maxweight=weight[height[x]]; if (tree[x].l!=0) { height[tree[x].l]=height[x]+1; weight[height[tree[x].l]]++; search(tree[x].l); } if (tree[x].r!=0) { height[tree[x].r]=height[x]+1; weight[height[tree[x].r]]++; search(tree[x].r); } } int main() { int n; cin>>n; for (int i=1;i<=n;i++) cin>>tree[i].l>>tree[i].r; height[1]=1; weight[1]=1; search(1); cout<<maxweight<<' '<<maxheight; return 0; }
相关文章推荐
- p1978 Fibonacci数列 3
- p1011
- p1475
- p1474
- p1842 递归第一次
- p3038 3n+1问题
- p3143 二叉树的序遍历
- p3145 汉诺塔游戏
- jsp使用cookie实现记住密码的功能
- [译]CasperJS,基于PhantomJS的工具包
- js中的apply()和call()执行域转换详解
- hdu 1299
- 课堂笔记08
- LeetCode 之 Palindrome Partitioning II(动态规划)
- Flash Builder4.6破解方案(亲测有效)(转)
- Android 微信下拉眼睛
- UVA - 10344 - 23 out of 5 (暴力)
- android XMPP即时通讯客户端
- POJ 1273 --Drainage Ditches【最大流模板 && dinic】
- hihocoder 第五十二周 高斯消元·二【高斯消元解异或方程 难点【模板】】