力扣每日一题----2008. 出租车的最大盈利

这题我们是怎么思考的呢? 

已知有乘客最多30000个,有最多100000个地点,那么通过算法时间复杂度,不可能是O(n^2),

那么我们就可以去看题目,题目又是最多盈利多少元?那么很容易联想到动态规划,并且我们又发现该数组排个序之后可以让其递归时某个状态呈现出递推性质,那么我们就确定是动态规划算法了

那么在确定是动态规划算法之后的话,我们该去怎么分析呢?是根据我们的经验去定义吗?

那么我们就以f[i]表示以当前i为下车点的最大值,那么这样去定义可以吗,其实是不太行的,因

为以当前i为结尾的话,我们必须记录第i个为下车点的时候值,如果没有那么就得是f[i] = 0,那么这样就比较麻烦,其实应该也是可以做的,只是这样做很麻烦。

那么我们试想以下这样去定义,f[i]表示在1~i之内接到的乘客的最大利润,那么我们发现,

f[i - 1]表示在1 ~ i - 1之内接到的乘客的最大利润。

枚举乘客

假设当前乘客是a,小于a上车点并且

b下车点 <= a上车点的乘客集合记作b

那么f[a下车点]要保证是最大的话,那么需要知道是否要接上a这个乘客,

如果要接上该乘客的话

    那么我们要保证f[a下车点]是最大的,

    那么就需要找到小于a上车点的最大利润的状态,又分为两种状态

   1.第一种,a乘客一定可以上车

    那么f[a下车点] = max({f[b集合的下车点],b E 1 ~ a上车点}) + 当前乘客的利润

  2.第二种,a乘客一定不能上车

     那么就需要找到小于a上车点的最大利润的状态,

    那么f[a下车点] = max({f[b集合的下车点],b E 1 ~ a上车点}) 

那么总结下来就是枚举当前,看前面

那么我们怎么枚举呢?

按照每个乘客的上车起点升序进行枚举。为什么呢?

那么枚举当前,怎么确保前面的值是最大的呢?用一个堆来维护小于当前st的最大利润

那么该什么时候入堆,什么时候出堆呢?

比如第一个乘客st是1,ed是5,

第二个乘客是st是2,ed是5,

第三个乘客是st是3,ed是7,

我们发现该组数据中,我们的车只能接三个乘客的一种,所以当st小于下车点的时候,

直接入堆即可,当遇到st大于等于下车点话,那么根据key(下车点)的堆进行判断,找到

前面乘客最大下车点(符合当前乘客st>=前面的乘客的最大下车点),找到之后,

就变成   1.第一种,a乘客一定可以上车

如果没有那就  2.第二种,a乘客一定不能上车

class Solution {
public:typedef pair<long long,long long> PLL;struct CompareFirst {bool operator()(const PLL& a, const PLL& b) {return a.first > b.first;  // ">" for a min heap, "<" for a max heap}
};long long maxTaxiEarnings(int n, vector<vector<int>> &rides) {vector<long long> f(n + 10);//按照st大小排序sort(rides.begin(), rides.end(), [&](const vector<int> &a, const vector<int> &b) -> bool {return a[0] < b[0];});int m = rides.size();priority_queue<PLL, vector<PLL>, CompareFirst> pq;long long res = 0,maxv = 0;for(int i = 0;i < m;i++){long long st = rides[i][0],ed = rides[i][1],tip = rides[i][2];while(!pq.empty() && pq.top().first <= st)//如果队头的下车时间小于当前的st,那么进行判断{//判断什么呢,找到比当前st小的最大值maxv = max(maxv,pq.top().second);pq.pop();}//找到之后计算出加上当前乘客的利润long long curv = maxv + ed - st + tip;//加上之后入堆res = max(res,curv);pq.push({ed,curv});}return res;}
};

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/217217.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

湖南大学-电路与电子学-2021期末A卷★(不含解析)

【写在前面】 电路与电子学好像是从2020级开设的课程&#xff0c;故实际上目前只有2020与2021两个年级考过期末考试。 本份卷子的参考性很高&#xff0c;这是2020级的期末考卷。题目都是很典型的&#xff0c;每一道题都值得仔细研究透。 特别注意&#xff1a;看得懂答案跟写得…

Linux学习笔记之八(进程间的共享内存)

Linux 1、引言2、实现共享内存2.1、创建一个共享内存2.2、将共享内存链接到进程空间2.3、断开与共享内存的链接2.4、对共享内存进行后续操作 3、应用实例 1、引言 在之前一篇文章Linux学习笔记之六&#xff08;进程之间的管道通信和信号处理&#xff09;中我讲了进程间可以通过…

sql 读写注入

root高权限读写注入 load_file 读取文件 大姐我真是整了半天都是nullnullnull缝子 结果看了半天这个my.ini是被隐藏的大哥 load_file()读取文件结果为null_mysql load_file返回null解决办法_黑小薛的博客-CSDN博客 终于读出来了 此时参数值系统变量 secure_file_priv已经被修…

Redis缓存如何设置时间?

在Redis中&#xff0c;你可以使用SET命令设置缓存&#xff0c;并使用EXPIRE命令设置key的过期时间。以下是一些基本的使用方法 设置缓存值 使用SET命令可以设置缓存值 SET key_name "your_value"这将在Redis中创建一个键为key_name&#xff0c;值为"your_val…

三天精通Selenium Web 自动化 - 项目实战环境准备

1 部署TestNG 返回 TestNG&#xff0c;即Testing Next Generation&#xff0c;下一代测试技术&#xff0c;是一套根据JUnit和NUnit思想而构建的利用注释来强化测试功能的一个测试框架&#xff0c;即可以用来做单元测试&#xff0c;也可以用来做集成测试。更多细节可以到官网去…

MacBook充不了电问题可大可小,但大部分通过简单的排除就可以解决

如果你的MacBook Pro或MacBook Air无法充电&#xff0c;或者充电器不工作&#xff0c;那么随着电池电量的耗尽&#xff0c;让其正常工作可能是在与时间赛跑。在这篇文章中&#xff0c;我们将了解Mac笔记本电脑可能无法充电的可能原因&#xff0c;以及如何修复。 我们还将研究如…

钩不了判断

直言命题 第一种&#xff1a;直言命题&#xff08;<3种元素&#xff09; 所有&#xff08;指所有&#xff1b;范围小&#xff09; 某个&#xff08;特指一个&#xff1b;范围小&#xff09; 有的、有些&#xff08;可以指一个、一部分、所有&#xff1b;范围大&#xff09;…

Java实现插入排序及其动图演示

插入排序是一种简单直观的排序算法。它的基本思想是将一个待排序的元素插入到已经排序好的序列中的适当位置&#xff0c;从而得到一个新的、元素个数加一的有序序列。 具体的插入排序算法过程如下&#xff1a; 从第一个元素开始&#xff0c;认为第一个元素已经是有序序列。取…

git常规操作流程(纯命令行操作)和一些注意事项

当你在单位拿到了git仓库,并利用公司给你的OA账号和邮箱完成了你的git基础配置,下面就是使用命令行的无错固定操作流程 如果你很着急,你可以直接跳到最后的总结部分 具体步骤 1.从仓库克隆代码到本地 这里的[codeUrl]就是你仓库的地址,当你在仓库点击图中绿色位置时,剪贴板…

SpringCloud+Consul快速开发示例

简介 本章通过最新的springcloud版本与官方最新consul开源版服务&#xff0c;进行演示&#xff0c;如何快速搭建开发环境和注册与发现服务中心&#xff1b; 本文假设已知具备SpringCloud的基础开发能力&#xff0c;以及提前了解consul服务的使用&#xff0c;因此本文不会详细…

孩子还是有一颗网安梦——Bandit通关教程:Level 9 → Level 10

&#x1f575;️‍♂️ 专栏《解密游戏-Bandit》 &#x1f310; 游戏官网&#xff1a; Bandit游戏 &#x1f3ae; 游戏简介&#xff1a; Bandit游戏专为网络安全初学者设计&#xff0c;通过一系列级别挑战玩家&#xff0c;从Level0开始&#xff0c;逐步学习基础命令行和安全概念…

网络基础(八):路由器的基本原理及配置

目录 1、路由概述 2、路由器 2.1路由器的工作原理 2.2路由器的转发原理 3、路由表 3.1路由表的概述 3.2路由表的形成 4、静态路由配置过程&#xff08;使用eNSP软件配置&#xff09; 4.1两个静态路由器配置过程 4.2三个静态路由器配置过程 5、默认路由配置过程 5.…

Qt 容器QGroupBox带有标题的组框框架

控件简介 QGroupBox 小部件提供一个带有标题的组框框架。一般与一组或者是同类型的部件一起使用。教你会用,怎么用的强大就靠你了靓仔、靓妹。 用法示例 例 qgroupbox,组框示例(难度:简单),使用 3 个 QRadioButton 单选框按钮,与QVBoxLayout(垂直布局)来展示组框的…

若依框架启动过程中遇到的控制台使用npm i下载相关依赖报错的问题以及前端启动遇到的问题

目录 报错截图问题解决其他问题 npm : 无法将“npm”项识别为 cmdlet、函数、脚本文件或可运行程序的名称。请检查名称的拼写&#xff0c;如果包括路径&#xff0c;请确保路径正确&#xff0c;然后再试一次。问题解决更改环境变量新建系统变量 其他问题 错误解决Error: error:0…

美食大赛的题解

目录 原题描述&#xff1a; 题目描述&#xff1a; 输入格式&#xff1a; 输出格式&#xff1a; 样例输入&#xff1a; 样例输出&#xff1a; 数据规模&#xff1a; 题目大意&#xff1a; 主要思路&#xff1a; 注&#xff1a; 代码&#xff1a; 原题描述&#xff1a…

Uniapp软件库全新带勋章功能(包含前后端源码)

源码介绍&#xff1a; Uniapp开发的软件库全新带勋章功能&#xff0c;搭建好后台 在前端找到 util 这个文件 把两个js文件上面的填上自己的域名&#xff0c;电脑需要下载&#xff1a;HBuilderX 登录账号 没有账号就注册账号&#xff0c; 然后上传文件&#xff0c;打包选择 “…

js 有关递归简单介绍

递归&#xff1a;指调用自身的函数 重点&#xff1a;递归函数必须有可以终止递归调用的语句&#xff0c;否则会导致内存溢出 递归的性能不好&#xff0c;因为在递归终止前&#xff0c;JavaScript引擎会为每一次递归分配一块内存以存储栈帧&#xff0c;随着递归的深入&#xff…

基于双树复小波变换和稀疏表示的多光谱和彩色图像融合算法matlab仿真

目录 1.算法运行效果图预览 2.算法运行软件版本 3.部分核心程序 4.算法理论概述 4.1 双树复小波变换原理 4.2 稀疏表示原理 4.3 基于双树复小波变换和稀疏表示的图像融合算法 5.算法完整程序工程 1.算法运行效果图预览 2.算法运行软件版本 MATLAB2022a 3.部分核心程序…

补充回答一些关于枚举类型的问题

补充回答一些关于枚举类型的问题 1.枚举类型在什么时候使用 枚举类型在以下情况下特别有用&#xff1a; 有限的离散值集合&#xff1a; 当变量的取值只有有限且离散的几个选项时&#xff0c;使用枚举类型能够提高代码的可读性。例如&#xff0c;星期几、月份、颜色等。 enum W…

讲解一手CSRF,如何防御CSRF

简介&#xff1a; CSRF&#xff08;Cross-Site Request Forgery&#xff0c;跨站请求伪造&#xff09;是一种网络安全漏洞&#xff0c;它允许攻击者通过欺骗用户在当前已登录的Web应用程序上执行未经用户授权的操作。 攻击者利用用户在目标网站上已经建立的身份认证&#xff…