九度OJ - 1350 - 二叉树的深度
2016-05-10 22:05
253 查看
题目描述
输入一棵二叉树,求该树的深度。从根结点到叶结点依次经过的结点(含根、叶结点)形成树的一条路径,最长路径的长度为树的深度。输入
第一行输入有n,n表示结点数,结点号从1到n。根结点为1。 n <= 10。接下来有n行,每行有两个个整型a和b,表示第i个节点的左右孩子孩子。a为左孩子,b为右孩子。当a为-1时,没有左孩子。当b为-1时,没有右孩子。
输出
输出一个整型,表示树的深度。样例输入
32 3
-1 -1
-1 -1
样例输出
2#include<cstdio> #include<iostream> #include<cstring> #include<algorithm> using namespace std; struct TreeNode{ int lchild; int rchild; }; TreeNode Tree[20]; int depthTree(int x, int n){ if(x < 1 || x > n) return 0; if(Tree[x].lchild==-1 && Tree[x].rchild==-1){ return 1; } int leftdepth = depthTree(Tree[x].lchild, n); int rightdepth = depthTree(Tree[x].rchild, n); return leftdepth >= rightdepth ? leftdepth+1 : rightdepth+1; } int main() { int n, left, right, depth; while(scanf("%d", &n)!=EOF){ for(int i = 1; i <= n; i++){ cin >> left >> right; Tree[i].lchild = left; Tree[i].rchild = right; } int depth = depthTree(1, n); cout << depth << endl; } return 0; }
相关文章推荐
- leetcode刷题,总结,记录,备忘 345
- Android中的通知 Notification
- mysql详解--mysql中的锁
- 第一章 JAVA入门(数据输入之EchoText类)
- Xcode关于拖拽窗口导致获取文件全路径错误的问题
- UVA 10859 Placing Lampposts(树形DP)
- Ubuntu环境下配置mysql
- C++_DFS求连通度
- Android的Handler,Looper消息机制问题
- 记第一次电话面试(百度)
- iOS学习——几种数据持久化方法
- APS.NET_MVC5学习笔记-从控制器访问数据模型
- NYOJ——301递推求值(矩阵快速幂)
- android studio 学习笔记之 全面进阶配置技巧
- 输出端口设为reg与wire的区别
- 5、深度剖析ConcurrentHashMap
- 修改textFieldplaceholder字体颜色和大小
- C++实验5:求和
- 【Android】自定义View —— 滑动的次数选择器
- 关于Java深度克隆和浅度克隆的简单说明