2023华为OD机试真题 C++【文件目录大小/深度优先搜索】

这篇博客介绍了华为在线开发者(OD)机试中的一道题目,要求使用C++编程计算指定目录及所有子目录的文件大小总和。通过深度优先搜索策略解决,文章提供了示例输入和输出,以及问题的解决方案。
摘要由CSDN通过智能技术生成

题目

你得到了一个文件系统的目录数据,每个目录都有一个唯一的ID、该目录内的文件大小和一些子目录。你的任务是计算指定目录及其所有子目录的文件大小总和。

输入格式

第一行:两个数字,M 和 N。其中,M 代表目录的总数,N 代表我们想查询的目录的ID。

接下来的 M 行:每行代表一个目录的信息,格式为:

目录ID 文件大小 子目录ID列表
目录ID:一个介于1到200之间的整数。
文件大小:一个介于1到1000之间的整数。
子目录ID列表:介于0到10个目录ID,用逗号分隔,放在括号里。例如:(2,3,4)。如果没有子目录,就是空括号()。
输出格式

输出指定目录及其所有子目录的文件大小总和。

示例

输入:

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

输出:
45
解释:目录1的大小是20,它有一个子目录2,大小是10;目录2又有一个子目录3,大小是15。所以,总的大小是20 + 10 + 15 = 45。

代码


                
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

codereasy

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

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

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

打赏作者

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

抵扣说明:

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

余额充值