lab24 天南地北

本博客介绍了一个计算古树村落群中相隔最远住宅距离的问题,即求解“天南地北”的距离。题目要求使用二叉链表实现,给出了满二叉树的输入表示,并提供了解题思路,包括如何由输入建立树、求树的高度以及找出天南地北的方法。博主分享了在编程过程中遇到的错误和解决经验,强调了细节的重要性。
摘要由CSDN通过智能技术生成

题目描述:

Description

本题要求使用二叉链表实现。

在华夏大地上曾存在一个古村落群,因其每一个村落内的住宅都按照树形分布,所以又被称为古树村落群。

其中村落内相隔最远(指从一个住宅到另一个住宅的路径的最大长度,并且住宅与住宅之间相连时才能通过,且不一定经过根节点)的两个住宅可以作为一对,被称为“天南”与“地北”。同一个村落内可能存在多对的天南与地北,天南与地北也有可能是同一个住宅。天南与地北的距离被称为一个村落的天地距。

小明无意间在古籍中查阅到了古树村落群的资料,里面记载了每一个村落的地图。你能帮帮小明计算出每一个村落的天地距吗?如下所示是一个村落的地图(满二叉树表示为[1 2 3 -1 -1 4 5]),其中天地距为3,因为天南与地北可以是2和4(2->1->3->4),也可以是2和5(2->1->3->5),但是相隔距离都是一样的。

 

Input

第一行输入一个数字,表示村落的层数

第二行输入村落地图的满二叉树表示,村落中至少有一个住宅。

Output

一个整数,表示该村落的天地距

example

input:

3
1 2 3 -1 -1 4 5

output&

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值