【新2023】华为OD机试 - 高效的任务规划(Python)

本文介绍了华为OD机试题中的高效任务规划问题,详细解析了如何使用贪心算法解决这个问题,以及提供了Python代码实现。核心知识点包括贪心策略和排序算法。文章提醒考生在准备华为OD机试时要理解解题思路,不要死记硬背代码。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

华为 OD 清单查看地址:blog.youkuaiyun.com/hihell/category_12199275.html

高效的任务规划

题目

你有 n 台机器编号为1-n,每台都需要完成一项工作,
机器经过配置后都能独立完成一项工作。
假设第i台机器你需要花 Bi 分钟进行设置,
然后开始运行,Ji分钟后完成任务。
现在,你需要选择布置工作的顺序,使得用最短的时间完成所有工作。
注意,不能同时对两台进行配置,
但配置完成的机器们可以同时执行他们各自的工作。

输入

第一行输入代表总共有 M 组任务数据(1 < M <= 10);
每组数第一行为一个整数指定机器的数量N(0 < N <= 1000)。
随后的 N 行每行两个整数,第一个表示B(0 <= B <= 10000),
第二个表示J(0 <= J <= 10000);
每组数据连续输入,不会用空行分割,各组任务单独计时

输出描述

对于每组任务,输出最短完成时间,
且每组的结果独占一行。
例如两组任务就应该有两行输出。

示例一

输入

1
1
2 2

输出

4

说明

输入共 3 行数据,
第一行代表只有 1 组任务;
第二行代表本组任务只有 1 台机器;
第三行代表本机器:配置需要 2 分钟,执行任务需要 2 分钟,
输出共一行数据,代表执行结果为 4 分钟

示例二

输入


                
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

梦想橡皮擦

如有帮助,来瓶可乐

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

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

打赏作者

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

抵扣说明:

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

余额充值