LeetCode刷题实战630:课程表 III程序IT圈关注共 1584字,需浏览 4分钟 ·2022-06-09 01:01 算法的重要性,我就不多说了吧,想去大厂,就必须要经过基础知识和业务逻辑面试+算法面试。所以,为了提高大家的算法能力,这个公众号后续每天带大家做一道算法题,题目就从LeetCode上面选 !今天和大家聊的问题叫做 课程表 III,我们先来看题面:https://leetcode.cn/problems/course-schedule-iii/There are n different online courses numbered from 1 to n. You are given an array courses where courses[i] = [durationi, lastDayi] indicate that the ith course should be taken continuously for durationi days and must be finished before or on lastDayi.You will start on the 1st day and you cannot take two or more courses simultaneously.Return the maximum number of courses that you can take.这里有 n 门不同的在线课程,按从 1 到 n 编号。给你一个数组 courses ,其中 courses[i] = [durationi, lastDayi] 表示第 i 门课将会 持续 上 durationi 天课,并且必须在不晚于 lastDayi 的时候完成。你的学期从第 1 天开始。且不能同时修读两门及两门以上的课程。返回你最多可以修读的课程数目。示例示例 1:输入:courses = [[100, 200], [200, 1300], [1000, 1250], [2000, 3200]]输出:3解释:这里一共有 4 门课程,但是你最多可以修 3 门:首先,修第 1 门课,耗费 100 天,在第 100 天完成,在第 101 天开始下门课。第二,修第 3 门课,耗费 1000 天,在第 1100 天完成,在第 1101 天开始下门课程。第三,修第 2 门课,耗时 200 天,在第 1300 天完成。第 4 门课现在不能修,因为将会在第 3300 天完成它,这已经超出了关闭日期。示例 2:输入:courses = [[1,2]]输出:1示例 3:输入:courses = [[3,2],[4,3]]输出:0解题https://blog.csdn.net/weixin_42051691/article/details/124830084主要思路:考虑两个因素,先考虑结束时间,其次考虑时间优先选取最快要结束的课程(2 5 ,3 6)如果当前课程时间冲突(完成时间大于结束时间),那么就从已经完成的课程中(包括当前课程)找一个需要时间最长的删除(当前课程优于时间长的课程)。class Solution {public:// 优先学习最快要结束的课程,如果课程冲突,则将已经上过的持续时间最长的课程排除 int scheduleCourse(vector<vector<int>>& courses) { priority_queue<int> pq; int n=courses.size(); // 按照结束时间排序 sort(courses.begin(),courses.end(),[](const vector<int>& l,const vector<int>& r){ if(l[1]==r[1]) return l[0]0]; return l[1]1]; }); int sum=0; for(int i=0;i pq.push(courses[i][0]); sum+=courses[i][0]; // 如果冲突,将前边时间最长的课程删去 if(sum>courses[i][1]) sum-=pq.top(),pq.pop(); } return pq.size(); }};上期推文:LeetCode1-620题汇总,希望对你有点帮助!LeetCode刷题实战621:任务调度器LeetCode刷题实战622:设计循环队列LeetCode刷题实战623:在二叉树中增加一行LeetCode刷题实战624:数组列表中的最大距离LeetCode刷题实战625:最小因式分解LeetCode刷题实战626:换座位LeetCode刷题实战627:变更性别LeetCode刷题实战628:三个数的最大乘积LeetCode刷题实战629:K个逆序对数组 浏览 6点赞 评论 收藏 分享 手机扫一扫分享分享 举报 评论图片表情视频评价全部评论推荐 LeetCode刷题指南!Datawhale0LeetCode神器,算法刷题宝典.pdf小白学视觉0LeetCode 啥题都有:Go 刷「打家劫舍」Go语言精选0LeetCode神器,算法刷题宝典.pdf视学算法0一起刷 LeetCode!Datawhale0刷题公子龙0刷LeetCode算法题的常见模式套路AI算法与图像处理0《LeetCode刷题答案》pdf出炉,赶紧刷起来...java12340LeetCode刷题笔记 - 14. 最长公共前缀该昵称无法识别0LeetCode 啥题都有:Go 刷「打家劫舍」二Go语言精选0点赞 评论 收藏 分享 手机扫一扫分享分享 举报