华为OD机考2025B卷 - 文件目录大小(Java & Python& JS & C++ & C )

最新华为OD机试

真题目录:点击查看目录
华为OD面试真题精选:点击立即查看

题目描述

一个文件目录的数据格式为:目录id,本目录中文件大小,(子目录id列表)。

其中目录id全局唯一,取值范围[1, 200],本目录中文件大小范围[1, 1000],子目录id列表个数[0,10]例如 : 1 20 (2,3) 表示目录1中文件总大小是20,有两个子目录,id分别是2和3

现在输入一个文件系统中所有目录信息,以及待查询的目录 id ,返回这个目录和及该目录所有子目录的大小之和。

输入描述

第一行为两个数字M,N,分别表示目录的个数和待查询的目录id,

  • 1 ≤ M ≤ 100
  • 1 ≤ N ≤ 200

接下来M行,每行为1个目录的数据:

目录id 本目录中文件大小 (子目录id列表)

子目录列表中的子目录id以逗号分隔。

输出描述

待查询目录及其子目录的大小之和

示例1

输入

3 1
3 15 ()
1 20 (2)
2 10 (3)

输出

45

说明

目录1大小为20,包含一个子目录2 (大小为10),子目录2包含一个子目录3(大小为15),总的大小为20+10+15=45

示例2

输入

4 2
4 20 ()
5 30 ()
2 10 (4,5)
1 40 ()

输出

60

说明

目录2包含2个子目录4和5,总的大小为10+20+30 = 60

解题思路

数据存储

:我们需要两个数据结构:

  • 目录大小映射:存储每个目录的文件大小。

  • 子目录映射:存储每个目录的子目录列表。

DFS遍历

:从查询目录ID开始,使用深度优先遍历(DFS)方式,计算该目录及其所有子目录的大小。

  • 初始时,将目标目录ID放入栈中。

  • 依次弹出栈中的目录ID,累加当前目录的文件大小。

  • 将当前目录的所有子目录压入栈中,继续遍历。

  • 直到栈为空,遍历结束。

  • 终止条件:当遍历所有目录之后,返回累计的大小总和。

Java


                
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

算法大师

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值