【力扣每日一题】2023.9.11 课程表Ⅲ

目录

题目:

示例:

分析:

代码:


题目:

示例:

分析:

今天是和前两天一样课程表,不过今天不太一样了,今天不是图论了,可以看作是全新的题目。

给我们一个课程数组,里面的元素是每个课程的学习所需花费时间和结课时间,我们需要在结课时间到达之前学习完课程。问我们最终可以学完多少门课程。

我们需要尽可能多得学习课程,那么必然是需要贪心的,问题在于我们需要怎么贪。我们应该先学习花费时间短的课程以及优先学习快结课的课程。

也就是在优先学习快结课的课程的基础上选择花费时间短的课程,结课时间的优先级较高,因此我们对课程数组按照结课时间来进行排序。

做完预处理之后,我们定义一个变量,表示目前所在的时间,初始化为0,表示我们在开学的第一天,每次学习完某门课程之后,我们就把这个时间加上学习花费的时间。

接着我们开始模拟学习课程,按照顺序遍历排完序的课程数组,如果当前的课程的花费时间加上我们所在的时间仍未超过当前课程的结课时间,那么我们学习这门课程,更新一下所在的时间点。

如果当前课程花费的时间加上我们所在的时间之后超过了结课时间,那么我们无法学习这门课程,不过我们可以贪心一下,如果这门课程花费的时间比我们学过的课程中花费最多的时间更少,那么我们可以选择不学那门花费更多的课程转为学习本门课程,因为我们是按照结课时间来排序,并且是按顺序遍历的,所以替换是不会发生冲突的。

为了更方便地获取我们学习过的课程的最大花费,我们可以拿一个大顶堆来存放已经学习过的课程的花费时间,每次学习了课程,我们就把花费时间放进去,每次替换了学习的课程,我们就将大顶堆的堆顶元素推出,再把新课程塞进去。

替换之后我们还需要更新一下时间点,因为学习课程花费的时间总量少了,因此我们需要补个"差价",把时间点再减去替换课程的花费时间之差。

最后遍历完毕,我们返回大顶堆的大小即可。

代码:

cpp 复制代码
class Solution {
public:
    int scheduleCourse(vector<vector<int>>& courses) {
        //按照截止日期来排序,优先学习临期课程
        sort(courses.begin(),courses.end(),[](auto &a,auto &b){return a[1]<b[1];});
        //大顶堆存放已经学习课程所花费的时间
        priority_queue<int> pq;     
        int start=0; 
        for (auto& c:courses) {
            //学习课程之后不超过规定的时间,那么可以学习,大顶堆中加入
            if(start+c[0]<=c[1]){ 
                pq.push(c[0]);
                start+=c[0];
            }
            //如果学习课程的时间小于已经学习的课程中时间最大的课程,那么可以替代掉
            else if(!pq.empty()&&pq.top()>c[0]){
                start-=pq.top()-c[0];   //时间上补个差价
                pq.pop();               //把大顶堆中的最大元素换出来
                pq.push(c[0]);          
            }
        }
        return pq.size();
    }
};
相关推荐
WBluuue9 分钟前
Codeforces 1093 Div2(ABCD1D2)
c++·算法
浅念-17 分钟前
「一文吃透 BFS:从层序遍历到锯齿形、最大宽度、每层最大值」
数据结构·算法
汉克老师19 分钟前
GESP5级C++考试语法知识(十三、贪心算法(一))
算法·贪心算法·海盗船·gesp5级·gesp五级·排队接水
玩转单片机与嵌入式1 小时前
玩转边缘AI(TInyML):需要掌握的C++知识汇总!
开发语言·c++·人工智能
历程里程碑1 小时前
4 Git远程协作:从零开始,玩转仓库关联与代码同步(带实操代码讲解)
大数据·c++·git·elasticsearch·搜索引擎·gitee·github
梦想画家1 小时前
Apache AGE实战指南:从Cypher语法到核心图算法
算法·cypher·apache age
刀法如飞2 小时前
Go数组去重的20种实现方式,AI时代解决问题的不同思路
后端·算法·go
汉克老师2 小时前
GESP5级C++考试语法知识(贪心算法(一)课堂例题精讲)
c++·贪心算法·gesp5级·gesp五级·贪心规律
墨染千千秋2 小时前
C++头文件的使用,和各个头文件与头文件用处
c++
呱呱巨基2 小时前
Linux 基础IO
linux·c++·笔记·学习