洛谷P4913 【深基16.例3】二叉树深度(c嘎嘎)

题目链接P4913 【深基16.例3】二叉树深度 - 洛谷 | 计算机科学教育新生态

题目难度 :普及

解题思路:本题要求树的深度,即求左右子树高度的最大值,首先我们用结构体存树左右节点,然后分别递归地去左右子树的深度。

下面奉上代码部分:

cpp 复制代码
#include<bits/stdc++.h>  // 万能头文件
using namespace std;
typedef long long ll;
const int N = 1e6 + 10;      
int n;
int ans;
 
struct node
{
	int left,right;
	
}tree[N];

void dfs(int id,int deep)
{
	if(id == 0) return;//到达叶子节点
	ans = max(ans,deep);
	dfs(tree[id].left,deep + 1);//递归求左子树的深度 
	dfs(tree[id].right,deep + 1);//递归求右子树的深度 
}
int main() {
    ios::sync_with_stdio(0);
    cin.tie(0), cout.tie(0);
    
    cin >> n;
    for(int i=1; i<=n; i++)   cin >> tree[i].left >> tree[i].right;
    
    dfs(1,1);
    
    cout << ans << '\n';
    	

  
    return 0;  
}
 
相关推荐
Hello娃的7 分钟前
【神经网络】反向传播BP算法
人工智能·神经网络·算法
遗憾是什么.7 分钟前
数据结构 -- 链表
数据结构·链表
ZouZou老师11 分钟前
C++设计模式之责任链模式:以家具生产为例
c++·设计模式·责任链模式
lynnlovemin12 分钟前
从暴力到高效:C++ 算法优化实战 —— 排序与双指针篇
java·c++·算法
hweiyu0017 分钟前
数据结构:无向图
数据结构
jinxinyuuuus18 分钟前
快手在线去水印:短链解析、API逆向与视频流的元数据重构
前端·人工智能·算法·重构
Flash.kkl23 分钟前
优先算法专题十五——BFS_FloodFill
算法·宽度优先
alan072129 分钟前
【mysql存储引擎为什么选择B+树】
数据结构
高洁0130 分钟前
向量数据库拥抱大模型
python·深度学习·算法·机器学习·transformer
慕容青峰32 分钟前
牛客小白月赛 103 C 题题解
c++·算法·sublime text