当前位置: 首页 > news >正文

大型的营销型网站网站建设图片属性设置

大型的营销型网站,网站建设图片属性设置,企业信息查询系统官网江苏,二级域名分发网站源码题目链接 Leetcode.1665 完成所有任务的最少初始能量 Rating : 1901 题目描述 给你一个任务数组 tasks,其中 tasks[i] [actuali, minimumi]: actuali是完成第 i 个任务 需要耗费 的实际能量。minimumi是开始第 i 个任务前需要达到的最低能…

题目链接

Leetcode.1665 完成所有任务的最少初始能量 Rating : 1901

题目描述

给你一个任务数组 tasks,其中 tasks[i] = [actuali, minimumi]

  • actuali是完成第 i 个任务 需要耗费 的实际能量。
  • minimumi是开始第 i 个任务前需要达到的最低能量

比方说,如果任务为 ````[10, 12]```且你当前的能量为 11 ,那么你不能开始这个任务。如果你当前的能量为 13 ,你可以完成这个任务,且完成它后剩余能量为 3 。

你可以按照 任意顺序 完成任务。

请你返回完成所有任务的 最少 初始能量。

示例 1:

输入:tasks = [[1,2],[2,4],[4,8]]
输出:8
解释:
一开始有 8 能量,我们按照如下顺序完成任务:
- 完成第 3 个任务,剩余能量为 8 - 4 = 4 。
- 完成第 2 个任务,剩余能量为 4 - 2 = 2 。
- 完成第 1 个任务,剩余能量为 2 - 1 = 1 。
注意到尽管我们有能量剩余,但是如果一开始只有 7 能量是不能完成所有任务的,因为我们无法开始第 3 个任务。

示例 2:

输入:tasks = [[1,3],[2,4],[10,11],[10,12],[8,9]]
输出:32
解释:
一开始有 32 能量,我们按照如下顺序完成任务:
- 完成第 1 个任务,剩余能量为 32 - 1 = 31 。
- 完成第 2 个任务,剩余能量为 31 - 2 = 29 。
- 完成第 3 个任务,剩余能量为 29 - 10 = 19 。
- 完成第 4 个任务,剩余能量为 19 - 10 = 9 。
- 完成第 5 个任务,剩余能量为 9 - 8 = 1 。

示例 3:

输入:tasks = [[1,7],[2,8],[3,9],[4,10],[5,11],[6,12]]
输出:27
解释:
一开始有 27 能量,我们按照如下顺序完成任务:
- 完成第 5 个任务,剩余能量为 27 - 5 = 22 。
- 完成第 2 个任务,剩余能量为 22 - 2 = 20 。
- 完成第 3 个任务,剩余能量为 20 - 3 = 17 。
- 完成第 1 个任务,剩余能量为 17 - 1 = 16 。
- 完成第 4 个任务,剩余能量为 16 - 4 = 12 。
- 完成第 6 个任务,剩余能量为 12 - 6 = 6 。

提示:

  • 1<=tasks.length<=1051 <= tasks.length <= 10^51<=tasks.length<=105
  • 1<=actual​i<=minimumi<=1041 <= actual​i <= minimumi <= 10^41<=actuali<=minimumi<=104

解法:贪心 + 排序

我们假设 ppp 为能够完成所有任务的能量。有 (a0,m0),(a1,m1),(a2,m2),(a3,m3),....,(an−1,mn−1)(a_0,m_0),(a_1,m_1) ,(a_2,m_2),(a_3,m_3),....,(a_{n-1},m_{n-1})(a0,m0),(a1,m1),(a2,m2),(a3,m3),....,(an1,mn1),共 nnn 个任务。

按照题目的要求,如下不等式成立:

  • p≥m0p \geq m_0pm0
  • p−a0≥m1p - a_0 \geq m_1pa0m1
  • p−a0−a1≥m2p - a_0 - a_1 \geq m_2pa0a1m2
  • p−a0−a1−a2≥m3p - a_0 - a_1 - a_2 \geq m_3pa0a1a2m3
  • p−a0−a1−a2−a3−...−an−2≥mn−1p - a_0 - a_1 - a_2 - a_3 - ...-a_{n-2} \geq m_{n-1}pa0a1a2a3...an2mn1

将其整理一下,得:

  • p≥m0p \geq m_0pm0
  • p≥a0+m1p \geq a_0 + m_1pa0+m1
  • p≥a0+a1+m2p \geq a_0 +a_1 + m_2pa0+a1+m2
  • p≥a0+a1+a2+m3p \geq a_0 +a_1 + a_2 + m_3pa0+a1+a2+m3
  • p≥a0+a1+a2+a3+....+an−2+mn−1p \geq a_0 +a_1 + a_2 + a_3 + .... +a_{n-2} + m_{n-1}pa0+a1+a2+a3+....+an2+mn1

由于我们要求的是最少的能量,即我们要使 ppp 的最大值 最小化

我们现在考虑,是否能让上面 n 个不等式右侧的最大值 变小

我们可以尝试交换相连的两项,看看会发生什么。交换 (ai,mi)(a_i,m_i)(ai,mi)(ai+1,mi+1)(a_{i+1},m_{i+1})(ai+1,mi+1)两项。

交换之前:

  • p≥a0+a1+a2+a3+....+ai−1+mi=P(i)p \geq a_0 +a_1 + a_2 + a_3 + .... +a_{i-1} + m_i = P(i)pa0+a1+a2+a3+....+ai1+mi=P(i)
  • p≥a0+a1+a2+a3+....+ai−1+ai+mi+1=P(i+1)p \geq a_0 +a_1 + a_2 + a_3 + .... +a_{i-1} + a_i + m_{i+1} = P(i+1)pa0+a1+a2+a3+....+ai1+ai+mi+1=P(i+1)

交换之后:

  • p≥a0+a1+a2+a3+....+ai−1+mi+1=P′(i)p \geq a_0 +a_1 + a_2 + a_3 + .... +a_{i-1} + m_{i+1} = P'(i)pa0+a1+a2+a3+....+ai1+mi+1=P(i)
  • p≥a0+a1+a2+a3+....+ai−1+ai+1+mi=P′(i+1)p \geq a_0 +a_1 + a_2 + a_3 + .... +a_{i-1} + a_{i+1} + m_i = P'(i+1)pa0+a1+a2+a3+....+ai1+ai+1+mi=P(i+1)

暂时只考虑这两项。交换之前的最大值为:max{P(i),P(i+1)}max\{P(i) , P(i+1)\}max{P(i),P(i+1)};交换之后的最大值为: max{P′(i),P′(i+1)}max\{P'(i) , P'(i+1)\}max{P(i),P(i+1)}

因为 P′(i+1)>P(i)P'(i+1) > P(i)P(i+1)>P(i) , P(i+1)>P′(i)P(i+1) > P'(i)P(i+1)>P(i)

我们要想让交换之后的最大值变小,即 max{P′(i),P′(i+1)}<max{P(i),P(i+1)}max\{P'(i) , P'(i+1)\} < max\{P(i) , P(i+1)\}max{P(i),P(i+1)}<max{P(i),P(i+1)}

等价于 P′(i+1)<P(i+1)P'(i+1) < P(i+1)P(i+1)<P(i+1),即 a0+a1+a2+a3+....+ai−1+ai+1+mi<a0+a1+a2+a3+....+ai−1+ai+mi+1a_0 +a_1 + a_2 + a_3 + .... +a_{i-1} + a_{i+1} + m_i < a_0 +a_1 + a_2 + a_3 + .... +a_{i-1} + a_i + m_{i+1}a0+a1+a2+a3+....+ai1+ai+1+mi<a0+a1+a2+a3+....+ai1+ai+mi+1

化简得,ai−mi>ai+1−mi+1a_i - m_i > a_{i+1} - m_{i+1}aimi>ai+1mi+1

所以我们要做的就是,找出所有的满足这样条件 ai−mi>ai+1−mi+1a_i - m_i > a_{i+1} - m_{i+1}aimi>ai+1mi+1 的相连两项,并将它们交换位置。这样做不一定会让最大值减小,但是绝对不会让最大值增大。

实际上我们没必要去模拟这个过程。我们只需要让 tasks 按照 ai−mia_i - m_iaimi从小到大的排序,最后再遍历模拟这个求最大值的过程即可。

时间复杂度:O(nlogn)O(nlogn)O(nlogn)

C++代码:

class Solution {
public:int minimumEffort(vector<vector<int>>& tasks) {sort(tasks.begin(),tasks.end(),[&](auto &a,auto &b){return a[0] - a[1] < b[0] - b[1];}) ;int p = 0 , s = 0;for(auto &e:tasks){p = max(p,s + e[1]);s += e[0];}return p;}
};
http://www.yayakq.cn/news/679857/

相关文章:

  • 织梦做的网站_别人提交给我留的言我去哪里看Wordpress怎么改成中文
  • 禅城建设网站数据指数
  • 网站开发支付宝网页布局排版
  • 做大型网站需要多少钱深圳网站建设 猴王网络
  • 小程序开发公司网站源码下载怎么知道网站是哪个公司做的
  • 做视频广告在哪个网站能够赚钱网站框架设计图
  • 去国外做网站wordpress 老板页
  • 网站翻书效果网站外包开发
  • 揭阳东莞网站建设韶关专业网站建设教程
  • 怎么做网站的登录界面个人公众号做网站
  • 烟台电子商务产业园网站建设通州区住房和城乡建设部网站
  • 铜城建设集团网站360免费网站建设
  • 微信公众号做推送的网站四川营销
  • 自己的网站发文章怎么做外链北京有哪些网站建设
  • 2018做网站的视频青岛关键词排名哪家好
  • 团支书登录智慧团建网站校园网站建设目标
  • 沭阳哪里有做网站推广的在百度上如何上传自己的网站
  • 有什么好的网站seo综合查询接口
  • 网站管理平台有哪些哈尔滨最新信息
  • 西安市网站韩都衣舍网站建设
  • python 做网站 案例北京网站建设价格
  • 广东省建设局官方网站网站批量创建程序
  • 合肥网站seo诊断作文网投稿
  • 厦门网站注册与网页设计公司知乎的网站建设和网站运营
  • 做防伪的网站平面图制作用什么软件
  • ipa文件自己网站怎么做下载标志设计名词解释
  • 厦门外贸网站建设 之家聚名网是干什么的
  • asp网站制作免费模板下载无需下载国外黄冈网站推广
  • 柳州建设网站经济适用房表格电子商务网站建设策划书的流程
  • 动态ip地址做网站菜谱网站开发