Leetcode 2895. Minimum Processing Time

  • [Leetcode 2895. Minimum Processing Time](#Leetcode 2895. Minimum Processing Time)
    • [1. 解题思路](#1. 解题思路)
    • [2. 代码实现](#2. 代码实现)

1. 解题思路

这一题整体上来说其实没啥难度,就是一个greedy算法,只需要想明白耗时长的任务一定要优先执行,不存在某个耗时长的任务后执行可以更快的完成的情况。

因此,我们只需要将耗时倒序排列之后顺序分配给各个闲置的CPU即可。

2. 代码实现

给出python代码实现如下:

python 复制代码
class Solution:
    def minProcessingTime(self, processorTime: List[int], tasks: List[int]) -> int:
        processorTime = sorted(processorTime)
        tasks = sorted(tasks, reverse=True)
        n = len(processorTime)
        ans = max(processorTime[i] + tasks[4*i] for i in range(n))
        return ans

提交代码评测得到:耗时591ms,占用内存32.8MB。

相关推荐
夏鹏今天学习了吗1 小时前
【LeetCode热题100(78/100)】爬楼梯
算法·leetcode·职场和发展
圣保罗的大教堂1 小时前
leetcode 712. 两个字符串的最小ASCII删除和 中等
leetcode
有一个好名字4 小时前
力扣-确定两个字符串是否接近
算法·leetcode·职场和发展
独自破碎E5 小时前
【层序遍历】序列化二叉树
leetcode
菜鸟233号5 小时前
力扣518 零钱兑换II java实现
java·数据结构·算法·leetcode·动态规划
VT.馒头7 小时前
【力扣】2622. 有时间限制的缓存
javascript·算法·leetcode·缓存·typescript
独自破碎E8 小时前
【新视角】输出二叉树的右视图
leetcode
Ka1Yan8 小时前
[链表] - 代码随想录 160. 相交链表
算法·leetcode·链表
小欣加油8 小时前
leetcode 174 地下城游戏
c++·算法·leetcode·职场和发展·动态规划
有一个好名字10 小时前
力扣-奇偶链表
算法·leetcode·链表