华为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 人。

那么“至少”情况该如何分析呢?此时需要利用到前面的“合并”操作。

由于这x个小朋友都各自反馈有y个人和自己小区相同。因此我们可以将这x个小朋友,分成多段,每段y+1个小朋友,而每段的这些小朋友是可以合并的,即最终会有:

ceil( x / (y + 1) ) * (y+1)

其中 ceil( x / (y+1) ) 就是分段数,这里向上取整的原因是,对于某一段不足y+1个小朋友时,

比如有4个小朋友都反馈有2个人和自己小区相同,那么这4个小朋友中,可以选择3人组成一段,剩余的4-3=1人单独组成一段,如下所示,3人组成一段的小区都是A,而单独组成一段的小区是B

A  A  A | B

其中 A A A 三个小朋友互相弥补,组成一段,因此不需要外人加入。而B小朋友说还有2个人和自己小区一样,而当前进行反馈的小朋友已经组合完了,因此需要额外加入2个外人。

A A A | B B B

上面策略其实就是求出,根据反馈相同小区y的小朋友的数量x,求出至少的分段数,而每个分段就是y+1人。


import Foundation

class Test_21 {
    var garden: [Int] = []

    func start() {
        print("输入:garden[] = {2, 2, 3}")
        garden = readLine()?.split(separator: " ").map { Int($0) ?? -1 } ?? []
        var dicSet: [Int: Int] = [:]
        // 有x个小朋友都反馈有y个人与自己小区相同
        garden.forEach { item in
            dicSet[item] = (dicSet[item] ?? 0) + 1
        }
        var ans = 0
        dicSet.keys.forEach { key in
            let all = Double(key + 1)
            ans += Int(ceil(Double(dicSet[key] ?? 0) / all) * all)
        }

        print("输出描述")
        print("\(ans)")
    }
}

func ODTest_21() {
    let test = Test_21()
    test.start()
}

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

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

全部评论

相关推荐

面试经验:技术面试在技术面试中,‌面试官通常会根据应聘者的简历和项目经验进行提问。‌以下是一些可能出现的技术面试问题:‌1、几乎所有面试都会从自我介绍开始,‌这是展示个人背景和能力的机会;面试官会详细询问应聘者的项目经验,‌包括项目内容、‌使用的技术栈、‌遇到的问题及解决方案可能会涉及编程语言、‌数据结构、‌算法、‌系统设计等方面的基础知识2、通过设定特定的情景,‌考察应聘者解决实际问题的能力3、直接测试应聘者的编程能力或特定技能业务面试业务面试中,‌面试官可能会询问应聘者对顺丰科技业务的了解,‌以及应聘者如何将自己的技能应用到实际工作中。‌此外,‌还可能会询问应聘者对公司文化的理解和个人职业规划等。‌HR面试HR面试主要关注应聘者的个人情况,‌包括自我介绍、‌对岗位的考虑因素(‌如薪资、‌个人成长、‌工作地点、‌工作强度等)‌、‌业余爱好、‌家庭情况、‌座右铭等。‌这些问题旨在全面了解应聘者的性格、‌观念、‌心态以及对工作的态度。‌顺丰科技25届校招内推启动!技术专场!【🍀内推码】0H0PCC(简历来源选择校园大使)【内推链接】https://campus.sf-express.com/m/?channel=29&referCode=0H0PCC#/newGraduatesList招聘岗位:物流、供应链、大数据、算法、研发多个岗位招聘地点:深圳、武汉等即刻投递,offer速得!投递的uu留下姓名缩写+岗位~
顺丰集团
|
校招
|
超多精选岗位
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务