最新华为OD机试真题-项目排期安排(200分)

🍭 大家好这里是清隆学长 ,一枚热爱算法的程序员

💻 ACM金牌🏅️团队 | 编程一对一辅导

✨ 本系列打算持续跟新华为OD-D卷的三语言AC题解

👏 感谢大家的订阅➕ 和 喜欢💗 和手里的小花花🌸

最新华为OD机试D卷目录,全、新、准,题目覆盖率达 95% 以上,支持题目在线评测

最新华为OD机试目录: https://www.nowcoder.com/discuss/636153620743897088?sourceSSR=users

📎 在线评测链接

项目排期安排(200分)

alt

🌍 评测功能需要 =>订阅专栏<= 后联系清隆解锁~

🍓OJ题目截图

alt

🍏 项目排期安排

问题描述

项目组共有 个开发人员,项目经理接到了 个独立的需求。每个需求的工作量不同,且每个需求只能由一个开发人员独立完成,不能多人合作。假定各个需求之间无任何先后依赖关系,设计算法帮助项目经理进行工作安排,使整个项目能用最少的时间交付。

输入格式

第一行输入为 个需求的工作量,单位为天,用空格隔开。例如:

6 2 7 7 9 3 2 1 3 11 4

表示共有 个需求,每个需求的工作量分别为 天, 天, 天, 天, 天, 天, 天, 天, 天, 天, 天。其中

第二行输入为项目组人员数量 ,例如:

2

表示共有 名员工,其中

输出格式

输出整个项目最快完成的天数。

样例输入

6 2 7 7 9 3 2 1 3 11 4
2

样例输出

28

样例解释

在样例中,需求可以分配如下:

  • 开发人员1:6 + 7 + 9 + 3 + 3 = 28 天
  • 开发人员2:2 + 7 + 2 + 1 + 11 + 4 = 27 天

所以,最快完成所有工作的天数为28天。

数据范围

题解

本题可以通过二分查找来确定最少的天数。先对工作量进行降序排序,然后采用二分法来查找最短的时间。

  1. 确定时间的上下界,上界是所有工作量的总和,下界是最小的工作量。
  2. 在每次二分查找中,检查是否可以在当前的天数限制下完成所有任务。如果可以,说明还可以缩短时间;如果不可以,说明需要更多时间。
  3. 通过递归分配任务给员工来判断当前时间限制是否可行。

参考代码

  • Python
def min_days_to_complete(work_lst, n):
    work_lst.sort(reverse=True)
    m = len(work_lst)
    total_hours = sum(work_lst)

    def check(days, count, people_work_lst):
        if count == m:
            return True
        for i in range(n):
            if work_lst[count] + people_work_lst[i] <= days:
                people_work_lst[i] += work_lst[count]
                if check(days, count + 1, people_work_lst):
                    return True
                people_work_lst[i] -= work_lst[count]
        return False

    l, r = 1, total_hours
    while l < r:
        mid = (l + r) // 2
        if check(mid, 0, [0] * n):
            r = mid
        else:
            l = mid + 1

    return l

if __name__ == "__main__":
    work_lst = list(map(int, input().split()))
    n = int(input())
    print(min_days_to_complete(work_lst, n))
  • Java
import java.util.*;

public class Main {
    public static void main(String[] args) {
        Scanner sc 

剩余60%内容,订阅专栏后可继续查看/也可单篇购买

最新华为OD机试-E+D卷 文章被收录于专栏

本专栏给大家提供了华为2024最新华为OD-E/D卷的题目汇总和(Java/Cpp/Python)三语言解析 + 部分题目提供OJ在线评测

全部评论
这和之前的哪个项目分配的题基本一样吧
1 回复 分享
发布于 07-29 11:35 江苏

相关推荐

09-13 17:53
已编辑
黑龙江科技大学 iOS开发
题目描述单词接龙的规则是:可用于接龙的单词首字母必须要前一个单词的尾字母相同;当存在多个首字母相同的单词时,取长度最长的单词,如果长度也相等,则取字典序最小的单词;已经参与接龙的单词不能重复使用。现给定一组全部由小写字母组成单词数组,并指定其中的一个单词作为起始单词,进行单词接龙,请输出最长的单词串,单词串是单词拼接而成,中间没有空格。输入描述输入的第一行为一个非负整数,表示起始单词在数组中的索引K,0&nbsp;&lt;=&nbsp;K&nbsp;&lt;&nbsp;N&nbsp;;输入的第二行为一个非负整数,表示单词的个数N;接下来的N行,分别表示单词数组中的单词。输出描述输出一个字符串,表示最终拼接的单词串。补充说明单词个数N的取值范围为[1,&nbsp;20];单个单词的长度的取值范围为[1,&nbsp;30];用例1输入06worddddadcdwordd输出worddwordda说明:先确定起始单词word,再接以d开头的且长度最长的单词dword,剩余以d开头且长度最长的有dd,da,dc,则取字典序最小的da,所以最后输出worddwordda。用例2输入46worddddadcdwordd输出dwordda说明:先确定起始单词word,剩余以d开头且长度最长的有dd,da,dc,则取字典序最小的da,所以最后输出dwordda。解题如下:#include&nbsp;&lt;iostream&gt;#include&nbsp;&lt;vector&gt;#include&nbsp;&lt;string&gt;using&nbsp;namespace&nbsp;std;//&nbsp;判断是否可以接龙bool&nbsp;canChain(const&nbsp;string&amp;amp;&nbsp;a,&nbsp;const&nbsp;string&amp;amp;&nbsp;b)&nbsp;{&nbsp;&nbsp;&nbsp;&nbsp;return&nbsp;a.back()&nbsp;==&nbsp;b.front();}int&nbsp;main()&nbsp;{&nbsp;&nbsp;&nbsp;&nbsp;int&nbsp;k,&nbsp;n;&nbsp;&nbsp;&nbsp;&nbsp;cin&nbsp;&gt;&gt;&nbsp;k&nbsp;&gt;&gt;&nbsp;n;&nbsp;&nbsp;&nbsp;&nbsp;vector&lt;string&gt;&nbsp;words(n);&nbsp;&nbsp;//&nbsp;存储单词列表&nbsp;&nbsp;&nbsp;&nbsp;vector&lt;bool&gt;&nbsp;used(n,&nbsp;false);&nbsp;&nbsp;//&nbsp;标记单词是否已经使用过&nbsp;&nbsp;&nbsp;&nbsp;for&nbsp;(int&nbsp;i&nbsp;=&nbsp;0;&nbsp;i&nbsp;&lt;&nbsp;n;&nbsp;++i)&nbsp;{&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;cin&nbsp;&gt;&gt;&nbsp;words[i];&nbsp;&nbsp;&nbsp;&nbsp;}&nbsp;&nbsp;&nbsp;&nbsp;string&nbsp;result&nbsp;=&nbsp;words[k];&nbsp;&nbsp;//&nbsp;结果字符串以起始单词开始&nbsp;&nbsp;&nbsp;&nbsp;used[k]&nbsp;=&nbsp;true;&nbsp;&nbsp;//&nbsp;标记起始单词已使用&nbsp;&nbsp;&nbsp;&nbsp;while&nbsp;(true)&nbsp;{&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;int&nbsp;nextIndex&nbsp;=&nbsp;-1;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;for&nbsp;(int&nbsp;i&nbsp;=&nbsp;0;&nbsp;i&nbsp;&lt;&nbsp;n;&nbsp;++i)&nbsp;{&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;//&nbsp;找到未使用的单词并且可以接龙&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;if&nbsp;(!used[i]&nbsp;&amp;amp;&amp;amp;&nbsp;canChain(result,&nbsp;words[i]))&nbsp;{&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;//&nbsp;如果没有选择单词或者当前单词比选择的单词更长或者相同长度但字典序更小&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;if&nbsp;(nextIndex&nbsp;==&nbsp;-1&nbsp;||&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;words[i].length()&nbsp;&gt;&nbsp;words[nextIndex].length()&nbsp;||&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;(words[i].length()&nbsp;==&nbsp;words[nextIndex].length()&nbsp;&amp;amp;&amp;amp;&nbsp;words[i]&nbsp;&lt;&nbsp;words[nextIndex]))&nbsp;{&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;nextIndex&nbsp;=&nbsp;i;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;}&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;}&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;}&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;//&nbsp;如果没有找到可以接龙的单词,跳出循环&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;if&nbsp;(nextIndex&nbsp;==&nbsp;-1)&nbsp;{&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;break;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;}&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;result&nbsp;+=&nbsp;words[nextIndex];&nbsp;&nbsp;//&nbsp;将选择的单词加入结果&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;used[nextIndex]&nbsp;=&nbsp;true;&nbsp;&nbsp;//&nbsp;标记该单词为已使用&nbsp;&nbsp;&nbsp;&nbsp;}&nbsp;&nbsp;&nbsp;&nbsp;//&nbsp;输出最终拼接的单词串&nbsp;&nbsp;&nbsp;&nbsp;cout&nbsp;&lt;&lt;&nbsp;result&nbsp;&lt;&lt;&nbsp;endl;&nbsp;&nbsp;&nbsp;&nbsp;return&nbsp;0;}
查看1道真题和解析 投递华为等公司10个岗位
点赞 评论 收藏
分享
2 2 评论
分享
牛客网
牛客企业服务