华为OD机试A卷 - 获取最多食物(C++ Java JavaScript Python )

题目描述

主办方设计了一个获取食物的游戏。

游戏的地图由 N N N 个方格组成,每个方格上至多 2 2 2 个传送门,通过传送门可将参与者传送至指定的其它方格。
同时,每个方格上标注了三个数字:

  1. 第一个数字 i d id id:代表方格的编号,从 0 0 0 到 N − 1 N-1 N−1,每个方格各不相同;
  2. 第二个数字 p a r e n t − i d parent-id parent−id:代表从编号为 p a r e n t − i d parent-id parent−id 的方格可以通过传送门传送到当前方格( − 1 -1 −1 则表示没有任何方格可以通过传送门传送到此方格,这样的方格在地图中有且仅有一个);
  3. 第三个数字 v a l u e value value:取值在 [ 100 , 100 ] [100,100] [100,100] 的整数值,正整数代表参与者得到相应取值单位的食物,负整数代表失去相应数值单位的食物(参与者可能存在临时持有食物为负数的情况), 0 0 0 则代表无变化。

此外,地图设计时保证了参与者不可能到达相同的方格两次,并且至少有一个方格的value 是正整数。

游戏开始后,参与者任意选择一个方格作为出发点,当遇到下列情况之一退出游戏:

  • 参与者当前所处的方格无传送门;
  • 参与者在任意方格上主动宣布退出游戏。

请计算参与者退出游戏后,最多可以获得多少单位的食物。

输入描述

第一行: 方块个数N (N <10000)
接下来输入N行(id<Nparent-id < N,),每行记录了相应方格上标注的3个数字,即id (0 <= id < 10000) 、parent-id (0 <= parent-id < 10000和value (-100<= value <= 100)
特殊的 parent-id 可以取-1, 则表示没有任何方格可以通过传送门传送到此方格,这样的方格在地图中有且仅有一个。

输出描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

算法大师

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

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

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

打赏作者

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

抵扣说明:

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

余额充值