华为OD算法开发指导-任务规划

算法描述

给定n台机器,其编号由0到n-1,每台机器执行工作任务的流程分为两个阶段,第一阶段是配置阶段STEP1,该阶段所有机器是串行工作,第二阶段是运行阶段STEP2,该阶段是并行工作,现在需要分配机器的工作任务,使得所有机器执行工作任务的总时间最小。

输入描述

第一行输入M,表示M组任务数据,第二行开始输入每组任务的详细数据,每组任务的第一行输入N,表示N台机器,每组任务的第二行输入机器的配置阶段STEP1与运行阶段STEP2的执行工作任务的时间数据。

输出描述

每行输出M组任务执行工作的最小总时间。

测试用例

|--------------------------------|
| 输入: 2 2 3 2 2 3 1 6 7 输出: 7 13 |

算法逻辑分析

|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 配置阶段STEP1是串行任务,在该阶段每台机器是依次执行任务,其执行的总时间不变,运行阶段STEP2是并行任务,在该阶段所有机器是同时执行任务,则执行时间最长的机器应优先运行。 使用三维数组的数据结构保存M组任务的数据,例如,[[[3,2],[2,3]],[[6,6]]],其中 ,第二维数组的元素[[3,2],[2,3]]表示一组任务的详细数据,第三维数组的元素表示每台机器的配置阶段STEP1与运行阶段STEP2的执行工作任务的时间数据,以此类推。 对第二维数组的数组元素的运行阶段STEP2的数据执行大小排序,运行阶段STEP2的执行时间最长的机器应排在最前面,表示优先运行。 计算配置阶段STEP1的任务执行总时间,计算运行阶段STEP2的任务执行总时间,其中,所有机器在运行阶段STEP2的并行执行时间段,只计算一次该执行时间段的时间。 |

Java算法代码

算法主函数:

排序主函数:

计算主函数:

生成测试数据函数:

算法测试

测试用例:

相关推荐
兩尛5 天前
猴子爬山od
算法·华为od
我是华为OD~HR~栗栗呀5 天前
23届(华为od)-C开发面经
java·c语言·c++·python·华为od·华为·面试
兩尛6 天前
【华为OD机试】运维日志排序
java·数据结构·华为od
Tony_yitao8 天前
12.华为OD机试 - N个选手比赛前三名、比赛(Java 双机位A卷 100分)
java·算法·华为od·algorithm
我是华为OD~HR~栗栗呀9 天前
华为OD-C面经-23届学院哦
java·c++·python·华为od·华为·面试
无限码力12 天前
【全网首发】2025华为OD机试双机位C卷(机考全真题库)含考点说明(华为OD上机考试双机位C卷)
华为od·华为od机考·华为od机试·华为od机试双机位c卷·华为od机考双机位c卷·华为od上机考试双机位c卷
询问QQ:2769988517 天前
RRT星三维路径搜索Matlab代码分享[特殊字符]
华为od
Tony_yitao1 个月前
9.华为OD机试真题 - 最长的顺子 - 2024E卷 Java
java·华为od·algorithm
uesowys1 个月前
华为OD算法开发指导-简易内存池
java·算法·华为od