一、题目描述
当前IT部门支撑了子公司颗粒化业务,该部门需要实现为子公司快速开租建站的能力,建站是指在一个全新的环境部署一套IT服务。
每个站点开站会由一系列部署任务项构成,每个任务项部署完成时间都是固定和相等的,设为1。部署任务项之间可能存在依赖,假如任务2依赖任务1,那么等任务1部署完,任务2才能部署。任务有多个依赖任务则需要等所有依赖任务都部署完该任务才能部署。
没有依赖的任务可以并行部署,优秀的员工们会做到完全并行无等待的部署。
给定一个站点部署任务项和它们之间的依赖关系,请给出一个站点的最短开站时间。
二、输入描述
第一行是任务数taskNum,第二行是任务的依赖关系数relationsNum接下来 relationsNum 行,每行包含两个id,描述一个依赖关系,格式为: Di Dj,表示部署任务部署完成了,部署任务j才能部署,IDi 和IDj 值的范围为: [0,taskNum)注:输入保证部署任务之间的依赖不会存在环。
三、输出描述
1个整数,表示一个站点的最短开站时间。
四、解题思路
- 创建map,用于存储任务之间的依赖关系,key为任务编号,value为依赖该任务的任务列表;
- 循环读取num数据,将依赖关系存储map;
- 创建一个长度为n的数组,存储每个任务的最小启动时间;
- 创建变量time,用于记录最短开站时间;
- 递归调用,计算任务的最小启动时间;
- 如果当前任务没有依赖,表示该任务可以立即启动,将其最小启动时间设置为1,并返回1,停止递归;
- 遍历当前任务依赖的任务列表,递归调用getMinTime函数来获取依赖任务的最小启动时间,取其中的最大值作为当前任务的最小启动时间minDependTime;
- 当前任务的最小启动时间为依赖任务的最小启动时间加1,将该值记录到timeArr数组中,并返回该值;
- 输出最短开站时间time;
五、Python算法源码
def get_min_time(index, mapping, time_arr):
lst = mapping.get(index, [])
if len(lst) == 0:
time_arr[index] = 1
return 1
min_depend_time = -float("inf")
for task_num in lst:
if time_arr[task_num] is None:
time_arr[task_num] = get_min_time(task_num, mapping, time_arr)
min_depend_time = max(min_depend_time, time_arr[task_num])
need_time = min_depend_time + 1
time_arr[index] = need_time
return need_time
def shortest_open_time(task_num, relations_num, relations):
mapping = {}
for left, right in relations:
if left not in mapping:
mapping[left] = []
mapping[left].append(right)
time_arr = [None] * task_num
res = 0
for i in range(task_num):
need_time = get_min_time(i, mapping, time_arr)
res = max(res, need_time)
return res
六、效果展示
1、输入
5
5
0 4
1 2
1 3
2 3
2 4
2、输出
3
3、说明
有5个部署任务项,5个依赖关系,如下图所示。我们可以先同时部署任务项0和任务项1,然后部署任务项2,最后同时部署任务项3和任务项4。最短开站时间为3。
🏆下一篇:华为OD机试真题 Python 实现【相对开音节】【2022Q4 100分】,附详细解题思路
🏆本文收录于,华为OD机试(Python)真题(A卷+B卷)
每一题都有详细的答题思路、详细的代码注释、样例测试,订阅后,专栏内的文章都可看,可加入华为OD刷题群(私信即可),发现新题目,随时更新,全天CSDN在线答疑。