华为OD机试 - 编程能力提升计划 - 二分查找(Java 双机位C卷 100分)

在这里插入图片描述

华为OD机试 双机位C卷题库疯狂收录中,刷题点这里

专栏导读

本专栏收录于《华为OD机试(JAVA)真题》

刷的越多,抽中的概率越大,私信哪吒,备注华为OD,加入华为OD刷题交流群,每一题都有详细的答题思路、详细的代码注释、3个测试用例、为什么这道题采用XX算法、XX算法的适用场景,发现新题目,随时更新,全天优快云在线答疑。

一、题目描述

为了提升软件编码能力,小王制定了刷题计划,他选了题库中的 n 道题,编号从 0 到 n-1,并计划在 m 天内按照题目编号顺序刷完所有的题目(注意,小王不能用多天完成同一题)。

在小王刷题计划中,小王需要用 time[i] 的时间完成编号 i 的题目。

此外,小王还可以查看答案,可以省去该题的做题时间。为了真正达到刷题效果,小王每天最多直接看一次答案。

我们定义 m 天中做题时间最多的一天耗时为 T(直接看答案的题目不计入做题总时间)。

请你帮小王求出最小的 T 是多少。

二、输入描述

第一行输入为 time 数组,time[i] 的时间完成编号 i 的题目

第二行输入为 m,m 表示几天内完成所有题目,1 ≤ m ≤ 180

三、输出描述

最小耗时整数 T

四、测试用例

测试用例1:

1、输入

999,999,999
4

2、输出

0

3、说明

在前三天中,小王每天都直接看答案,这样他可以在三天内完成所有的题目并不花任何时间

测试用例2:

1、输入

1,2,2,3,5,4,6,7,8
5

2、输出

4

3、说明

第一天完成前3题,第3题看答案;
第二天完成第4题和第5题,第5题看答案;
第三天完成第6和第7题,第7提看答案;
第四天完成第8题,直接看答案;
第五天完成第9题,直接看答案

五、解题思路

最小化“每天做题时间上限 T”,用二分 + 贪心判定即可。

核心判定:一天内一段连续题目可行当且仅当 sum - max <= T(跳过耗时最大的一题)。

判定方法:对固定 T,用贪心划分每天尽量多的题。一天内可跳过 1 题,故当天有效耗时为 sum - max,只要 sum - max <= T 就可行。

数据结构:数组存储时间;使用累计和与当前最大值即可,空间 O(1)。

六、Java算法源码

public class OdTest {
    public static void main(String[] args) throws Exception {
        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
        String line1 = br.readLine();
        if (line1 == null) return;
        String line2 = br.readLine();
        if (line2 == null) return;

        // 解析 time 数组(逗号分隔,允许空格)
        line1 = line1.trim();
        if (line1.isEmpty()) return;
        String[] parts = line1.split("\\s*,\\s*");
        int n = parts.length;
        long[] time = new long[n];
        long sum = 0;
        long maxVal = 0;
        for (int i = 0; i < n; i++) {
            time[i] = Long.parseLong(parts[i]);
            sum += time[i];
            if (time[i] > maxVal) maxVal = time[i];
        }

        int m = Integer.parseInt(line2.trim());

        // 二分答案 T,范围 [0, sum]
        long left = 0;
        long right = sum; // 最大不会超过总和
        while (left < right) {
            long mid = (left + right) / 2;
            if (canFinish(time, m, mid)) {
                right = mid;
            } else {
                left = mid + 1;
            }
        }
        System.out.print(left);
    }

    // 判定在最大日做题时间 T 下,是否能在 m 天内完成
    private static boolean canFinish(long[] time, int m, long T) {
        int days = 1;
        long sum = 0;
        long max = 0;

        for (long t : time) {
            // 尝试把当前题目加入当天
            long newSum = sum + t;
            long newMax = Math.max(max, t);

            // 若加入后“跳过最大题”的时间仍 <= T,则可继续
            if (newSum - newMax <= T) {
                sum = newSum;
                max = newMax;
            } else {
                // 开启新的一天
                days++;
                sum = t;
                max = t;
                if (days > m) return false;
            }
        }
        return true;
    }
}

七、效果展示

1、输入

10,1,1,10
2

2、输出

1

3、说明

分为 [10,1]、[1,10],各自跳过 10,最大 1。

在这里插入图片描述


🏆下一篇:华为OD机试 - 简易内存池 - 逻辑分析(Java 双机位C卷 200分)

🏆本专栏收录于《华为OD机试(JAVA)真题》

刷的越多,抽中的概率越大,私信哪吒,备注华为OD,加入华为OD刷题交流群,每一题都有详细的答题思路、详细的代码注释、3个测试用例、为什么这道题采用XX算法、XX算法的适用场景,发现新题目,随时更新,全天优快云在线答疑。

在这里插入图片描述

华为OD-编码能力提升计划华为公司为了提升员工编码能力而设立的一项培训计划。该计划旨在帮助员工提高编码技能,提升编码水平,以满足公司快速发展和竞争的需求。 首先,编码是现代软件开发中非常重要的一个环节。通过该计划,员工可以学习到新的编码技术和方法,了解最新的编码规范和标准。同时,他们还可以接触到公司内部的编码案例和经验,学习到优秀团队的编码思维和实践。这些都将有助于员工提高编码质量,减少代码错误和缺陷。 其次,华为OD-编码能力提升计划还提供了一系列的培训课程和学习资源。员工可以参加在线培训、课程讲座和编码指导等活动,学习到各种不同的编码技术和方法。此外,还提供了学习资料和练习题,让员工能够进行实践和巩固所学知识。 此外,华为OD-编码能力提升计划还提供了一对一的指导和辅导。每位员工都可以与专业导师进行面对面的交流和讨论,获得个性化的学习建议和指导。导师会根据员工的实际情况和需求,给出适合他们的学习计划和目标。这样,员工可以更加有针对性地提高编码能力。 最后,华为OD-编码能力提升计划还鼓励员工参与编码评估和竞赛活动。通过参与这些活动,员工可以检验自己的编码水平和能力,并与其他优秀的编码人员进行交流和对比。这有助于激发员工的学习热情和竞争激励,进一步提高他们的编码能力。 总的来说,华为OD-编码能力提升计划为员工提供了学习和成长的会。通过这个计划,员工可以提高自己的编码技能,为公司的发展做出更大的贡献。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

哪 吒

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

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

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

打赏作者

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

抵扣说明:

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

余额充值