华为OD统一考试 - 小朋友至少有几个

题目描述

幼儿园组织活动,老师布置了一个任务:

每个小朋友去了解与自己同一个小区的小朋友还有几个。

我们将这些数量汇总到数组 garden 中。

请根据这些小朋友给出的信息,计算小朋友至少有几个?

输入描述

输入:garden[] = {2, 2, 3}

输出描述

输出:7

备注

  • garden 数组长度最大为 999
  • 每个小区的小朋友数量最多 1000 人,也就是 garden[i] 的范围为 [0, 999]

用例

输入

2 2 3

输出

7

说明

第一个小朋友反馈有两个小朋友和自己同一小区,即此小区有3个小朋友。

第二个小朋友反馈有两个小朋友和自己同一小区,即此小区有3个小朋友。

这两个小朋友,可能是同一小区的,且此小区的小朋友只有3个人。

第三个小区反馈还有3个小朋友与自己同一小区,则这些小朋友只能是另外一个小区的。这个小区有4个小朋友。

题目解析

本题的输出其实是至少的小朋友数量

假设:

  • 小朋友A反馈有x个人与自己的小区相同
  • 小朋友B反馈有y个人与自己的小区相同

那么,在什么情况下,可以假设小朋友A和小朋友B是同一个小区的?

答案:只有当x == y时,A和B的小区才可能是相同的。

比如:

小朋友A反馈有1个人和自己小区相同,小朋友B反馈有2个人和自己小区相同。

那么此时小朋友A和小朋友B的小区必然不同。

比如:

小朋友A反馈有1个人和自己小区相同,小朋友B也反馈有1个人和自己小区相同。

那么此时小朋友A,B可能是同一个小区的。并且可以进一步假设该小区只有A,B两个小朋友,即我们可以认为A,B发生了合并。

假设:有x个小朋友都反馈有y个人与自己小区相同

那么此时“至多”有 x * (y+1) 个小朋友,即这x个小朋友的小区各不相同,而这x个小朋友的每一个人都反馈还有y个人的小区和自己相同,即每一个小区都有 y + 1 人。

那么“至少”情况该

剩余60%内容,订阅专栏后可继续查看/也可单篇购买

2024华为OD机试卷题 文章被收录于专栏

本专栏给大家提供了华为2024最新华为OD 题目汇总。华为OD机试刷题记录机考算法题库,帮助你上岸华为。提供C++/Java、JavaScript、Python四种语言的解法。

全部评论
华为OD统一考试 - 小朋友至少有几个
点赞 回复 分享
发布于 09-20 18:14 四川

相关推荐

最讨厌装boyi的二🔥:服从性测试😉
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
10-05 10:13
已编辑
HHHHaos:让这些老登来现在秋招一下,简历都过不去
点赞 评论 收藏
分享
1 1 评论
分享
牛客网
牛客企业服务