华为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算法代码

算法主函数:

排序主函数:

计算主函数:

生成测试数据函数:

算法测试

测试用例:

相关推荐
开开心心_Every11 小时前
家常菜谱软件推荐:分类齐全无广告步骤详细
linux·运维·服务器·华为od·edge·pdf·华为云
无限码力1 天前
华为OD2026最新机试双机位C卷机考真题目录含考点说明 (持续更新)
华为od·华为od机考·华为od题库·华为od机试·华为od机试双机位c卷·华为od最新上机考试题库·od机考题库
无限码力1 天前
华为OD技术面真题 - 数据库MySQL - 3
数据库·mysql·华为od·八股文·华为od技术面八股文
无限码力1 天前
华为OD技术面真题 - JAVA开发 - 5
java·华为od·面试·华为od技术面真题·华为od技术面八股·华为od技术面java八股文
无限码力2 天前
华为OD技术面真题 - 数据库Redis - 2
数据库·redis·华为od·面试真题·华为od技术面真题·华为od技术面八股文·华为od高频面试真题
无限码力3 天前
华为OD技术面真题 - 数据库MySQL - 2
数据库·华为od·华为od技术面真题·华为od技术面八股·华为od面试八股文·华为od技术面mysql问题
无限码力3 天前
华为OD技术面真题 - 数据库Redis - 1
redis·华为od·华为od技术面真题·华为od技术面八股·华为od技术面八股文·华为od技术面redis问题
无限码力4 天前
华为OD技术面真题 - JAVA开发 - 4
华为od·华为od技术面真题·华为od技术面八股·华为od技术面java相关问题·华为od八股文
无限码力4 天前
华为OD技术面真题 - 数据库Mysql - 1
mysql·华为od·华为od技术面真题·华为od技术面八股·华为od技术面mysql八股