洛谷 P4913 二叉树深度(递归)

news2024/12/23 18:12:48

题目描述

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

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

输入格式

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

之后 𝑛 行,第 𝑖 行两个整数 𝑙、𝑟,分别表示结点 𝑖 的左右子结点编号。若 𝑙=0 则表示无左子结点,𝑟=0 同理。

输出格式

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

这道题的递归开始的时候比较难理解,一定要有逆向思维,先看代码吧:

#include <iostream>
#include <algorithm>
using namespace std;

const int MAXN = 1e6 + 10;
int n;

struct node{
	int left;
	int right;
};
node a[MAXN];

int dfs(int x){
	if(x == 0) return 0;
    else return max(dfs(a[x].left),dfs(a[x].right)) + 1;
}
int main(){
	cin >> n;
	for(int i=1;i<=n;i++){
		cin >> a[i].left >> a[i].right;
	}
	cout << dfs(1) << endl;
	return 0;
}

以题目的例子来讲:dfs(1)之后max(dfs(2),dfs(7))+ 1,这里dfs(7)返回1了,因为他没有节点都是0,然后2继续搜下去一直到max(dfs(4),dfs(5))+ 1,那这里就返回1了,因为他俩都没节点,一直回去就行,每次大的+1

加油

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1814807.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【大模型应用开发极简入门】提示工程二:零样本学习、少样本学习与改善提示效果

文章目录 一. 逐步思考&#xff1a;零样本思维链1. 数学计算推理2. 注意有效的方面 二. 少样本学习1. 基于提示词示例的学习2. 单样本学习 三. 改善提示效果1.指示模型提出更多问题2.格式化输出3.重复指示4.使用负面提示5. 添加长度限制 一. 逐步思考&#xff1a;零样本思维链 …

AI大模型的战场:通用大模型与垂直大模型的对决

引言 随着人工智能技术的不断进步&#xff0c;AI大模型在各个领域的应用也日益广泛。如今&#xff0c;AI大模型的战场正在分化&#xff0c;主要分为通用大模型和垂直大模型两个方向。通用大模型由于其适用范围广泛&#xff0c;在落地场景中占据了较大的优势。而垂直大模型则凭…

python3的基本语法说明三

一. 简介 前面几篇文章简单学习了 python3的基本语法&#xff0c;文章如下&#xff1a; python3的基本语法说明一-CSDN博客 python3的基本语法说明二-CSDN博客 本文继续学习 python3的基本语法。 二. python3 的基本语法 1. 等待用户输入 执行下面的程序在按回车键后就会…

就业班 第四阶段(k8s) 2401--6.11 day5 CICD实践+VPN+LDAP域管理+还有一些云产品

CICD项目实践&#xff08;扩展&#xff09; RBAC 角色&#xff1a;role 用户&#xff1a;user 角色绑定&#xff1a;rolebinding 需要自己指定好名称空间&#xff0c;只对某个名称空间有权限 集群角色&#xff1a;clusterrole 集群角色绑定&#xff1a;clusterrolebindin…

[初阶数据结构] 包装类 | 泛型

目录 一. 包装类 1.1 什么是包装类? 1.2 包装类的意义 1.3 基本数据类型与包装类 1.4 装箱 1.5 拆箱 1.6 小总结 二. 泛型 2.1 什么是泛型? 2.2 泛型的意义 2.3 泛型的语法 2.4 泛型的编译 2.4.1 下载插件 2.4.2 分析 2.5 上界 2.6 泛型方法 2.7 小总结 三. 总结 一.…

element-ui将组件默认语言改为中文

在main.js中加入以下代码即可 // 引入 Element Plus 及其样式 import ElementPlus from element-plus import element-plus/dist/index.css// 引入中文语言包 import zhCn from element-plus/es/locale/lang/zh-cn// 使用 Element Plus 并设置语言为中文 app.use(ElementPlus,…

乐鑫ESP32系列SOC技术让设备控制更简单,HMI智能屏方案应用

随着科技的飞速发展&#xff0c;我们的生活方式正在被重新定义。在智能家居领域&#xff0c;人机交互的便捷性和直观性一直是创新的焦点&#xff0c;如今正逐渐成为现实。 乐鑫以其先进的SoC技术&#xff0c;为智能家居行业带来了新的HMI智能屏方案。这一方案不仅集成了高性能…

商用OLED柔性屏,有42、48、55、65和77寸

商用OLED柔性屏在市场上的尺寸选择相对丰富&#xff0c;以下是针对您提到的42、48、55、65和77寸的具体信息&#xff1a; 42寸OLED柔性屏 目前市场上已有42寸的OLED柔性屏产品&#xff0c;如LG的42英寸电视柔性屏OLED&#xff0c;具有可曲直的特性&#xff0c;支持120Hz高刷新…

LogicFlow 学习笔记——1. 初步使用 LogicFlow

什么是 LogicFlow LogicFlow 是一个开源的前端流程图编辑器和工作流引擎&#xff0c;旨在帮助开发者和业务人员在网页端创建、编辑和管理复杂的业务流程和工作流。它提供了一个直观的界面和强大的功能&#xff0c;使得设计和管理工作流变得更加高效和便捷。 官网地址&#xff…

芯品荟 | 会议系统屏驱案例分享

一、产品简介 智能会议系统是一种对声、光、电等各种设备进行集中控制的设备。其可实现对会议过程进行签到、表决、多国语言翻译、现场摄像视像跟踪功能&#xff0c;并对进程中处以发言管理&#xff0c;达到人性化高科技水平&#xff0c;使会议可一键掌控。 系统要做到可方便快…

profiling模型性能分析与优化入门

一、定义 profiler 作用入门pyproftorch.summary/torchinfo 模型参数量分析以及模型可视化profiling 参数分析-模型分析 二、实现 1.profiler 作用&#xff1a;分析模型执行时间,内存占用 CPU/GPU 端Op执行时间统计 CPU/GPU 端Op输入Tensor的维度分析 Op的内存消耗统计 2. 入…

3D开发工具HOOPS如何推动3D打印应用实现数据格式转换、模型可视化?

3D打印技术的发展已经彻底改变了制造业、医疗、建筑和设计等众多领域。这一技术的核心在于其能够将数字模型转化为实物&#xff0c;而这一过程需要强大的软件支持。在这一领域&#xff0c;HOOPS作为一种专业的图形软件开发工具&#xff0c;发挥着至关重要的作用。 本文将深入探…

木板甲醛释放量气候箱法检测 木制品ENF级检测

甲醛释放量气候箱法检测 甲醛释放量气候箱法检测是一种用于评估木制品中甲醛释放量的标准测试方法。这种方法通常涉及将样品放置在一个密闭的气候箱内&#xff0c;模拟一定的温度、湿度和通风条件&#xff0c;然后定期测量箱内空气中的甲醛浓度。通过这些数据&#xff0c;可以计…

【ARM Cache 与 MMU 系列文章 7.5 -- ARMv8/v9 MMU FEAT_XS(XS Attribute)与 FEAT_MTE2 介绍】

请阅读【ARM Cache 及 MMU/MPU 系列文章专栏导读】 及【嵌入式开发学习必备专栏】 文章目录 MMU FEAT_XSXS AttributeXS Attribute 兼容性和影响XS Attribute 应用场景MMU FEAT_MTE2MTE2 主要目的和用途MTE2 工作原理MTE2 特性实现MTE2 注意事项MMU FEAT_XS 在ARMv8架构中,FE…

k8s之HPA,命名空间资源限制

一、HPA 的相关知识 HPA&#xff08;Horizontal Pod Autoscaling&#xff09;Pod 水平自动伸缩&#xff0c;Kubernetes 有一个 HPA 的资源&#xff0c;HPA 可以根据 CPU 利用率自动伸缩一个 Replication Controller、Deployment 或者Replica Set 中的 Pod 数量。 &#xff08;…

docker-compose部署一款老牌apm监控软件-- pinpoint(需定制docker镜像)

一、背景 公司测试环境需要重新部署一套apm监控软件&#xff0c;选择的是我们开发都使用过的pinpoint&#xff0c;当然首选使用docker-compose部署。 可是&#xff0c;在部署的过程中&#xff0c;却遇到了不少问题。 无法直接使用官网提供的docker-compose.yml&#xff0c;需…

ATA-3080C功率放大器在电解液体浸润性测试中的应用

现在的电子设备上的供电电池多为可反复充放电的锂电池&#xff0c;这种在我们日常生活中扮演着重要角色的电池&#xff0c;却有着自燃、爆炸的风险&#xff1b;随着电池在生活中的普及&#xff0c;电池检测相关行业和领域也随之发展。那么功率放大器在电解液体浸润性测试中有什…

Stack详解(含动画演示)

目录 Stack详解1、栈数据结构动画演示2、Stack的继承体系3、Stack的push (入栈)方法4、Stack的pop (出栈)方法5、Stack是如何利用Vector实现栈数据结构的&#xff1f;6、自己实现栈(不借助JDK提供的集合)7、自己实现栈(借助JDK提供的集合)利用 ArrayDeque 实现高性能的非线程安…

深入理解 Vue Router 及其 `router` 和 `route` 变量

深入理解 Vue Router 及其 router 和 route 变量 在使用 Vue.js 进行单页面应用开发时&#xff0c;Vue Router 是一个不可或缺的工具。它使得我们可以轻松地管理应用中的路由&#xff0c;提供了流畅的用户体验。然而&#xff0c;在实际开发中&#xff0c;许多开发者可能会混淆…

在自己的电脑上搭建我的世界Java版服务器

很多朋友&#xff0c;喜欢玩Minecraft&#xff0c;也希望搭建一个服务器&#xff0c;用于和小伙伴联机&#xff1b; 并且&#xff0c;拥有服务器后&#xff0c;即使所有玩家都下线&#xff0c;“世界”依旧在运行&#xff0c;玩家可以随时参与其中&#xff0c;说不定一上线&am…