洛谷P4913 二叉树深度

【洛谷P4913 深基16.例3】二叉树深度

文章目录

题目描述

有一个 n ( n ≤ 1 0 6 ) n(n \le 10^6) n(n≤106) 个结点的二叉树。给出每个结点的两个子结点编号(均不超过 n n n),建立一棵二叉树(根节点的编号为 1 1 1),如果是叶子结点,则输入 0 0

建好这棵二叉树之后,请求出它的深度。二叉树的深度是指从根节点到叶子结点时,最多经过了几层。

输入格式

第一行一个整数 n n n,表示结点数。

之后 n n n 行,第 i i i 行两个整数 l l l、 r r r,分别表示结点 i i i 的左右子结点编号。若 l = 0 l=0 l=0 则表示无左子结点, r = 0 r=0 r=0 同理。

输出格式

一个整数,表示最大结点深度。

样例 #1

样例输入 #1

复制代码
7
2 7
3 6
4 5
0 0
0 0
0 0
0 0

样例输出 #1

复制代码
4

正确代码

c++ 复制代码
#include <bits/stdc++.h>
#include <algorithm>
using namespace std;
int N;
const int MAXN = 1e6+5;
struct node {
    int l,r;
};

void dfs(int num, int deep);

node tree[MAXN];

int ans = 0;

int main() {
    cin >> N;
    for (int i=1; i<=N; i++) {
        cin >> tree[i].l >> tree[i].r;
    }
    dfs(1,1);
    cout << ans  << endl;
    return 0;
}

void dfs(int num, int deep) {
    if (num == 0) return ;
    ans = max(ans,deep);
    dfs(tree[num].l,deep+1);
    dfs(tree[num].r,deep+1);
}
相关推荐
南境十里·墨染春水4 小时前
C++传记(面向对象)虚析构函数 纯虚函数 抽象类 final、override关键字
开发语言·c++·笔记·算法
2301_797172754 小时前
基于C++的游戏引擎开发
开发语言·c++·算法
有为少年5 小时前
告别“唯语料论”:用合成抽象数据为大模型开智
人工智能·深度学习·神经网络·算法·机器学习·大模型·预训练
比昨天多敲两行6 小时前
C++ 二叉搜索树
开发语言·c++·算法
Season4506 小时前
C++11之正则表达式使用指南--[正则表达式介绍]|[regex的常用函数等介绍]
c++·算法·正则表达式
Tisfy6 小时前
LeetCode 2839.判断通过操作能否让字符串相等 I:if-else(两两判断)
算法·leetcode·字符串·题解
问好眼6 小时前
《算法竞赛进阶指南》0x04 二分-1.最佳牛围栏
数据结构·c++·算法·二分·信息学奥赛
会编程的土豆6 小时前
【数据结构与算法】优先队列
数据结构·算法
minji...8 小时前
Linux 进程信号(二)信号的保存,sigset_t,sigprocmask,sigpending
linux·运维·服务器·网络·数据结构·c++·算法
罗湖老棍子8 小时前
最大数(信息学奥赛一本通- P1549)(洛谷-P1198)
数据结构·算法·线段树·单点修改 区间求最大值