当前位置: 首页 > 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/436526/

相关文章:

  • 网站做电商销售需要注册吗芜湖做网站都有哪些
  • 创建网站的软件jquery 网站模板
  • 做物流网站有哪些功能企业网站建设方案及报价
  • 做h5比较好的网站极速网站建设定制价格
  • 网站域名跳转怎么做百度的网站域名
  • 国外的做外包项目的网站wordpress videopro
  • 快站优惠券去哪里找wordpress可视化编辑页面
  • 网站功能提升权限装修无忧网
  • 比较好的平面设计网站哈尔滨网站优化公司
  • 山东省建设厅网站特种作业seo全称
  • 苏宁易购网站建设方案小程序开发 与网站开发区别
  • 静态网站优化建立一个网店网站
  • 反恶意镜像网站中国工程建设网官方网站
  • 品牌商品怎么做防伪网站深圳网站建设响应式网站
  • 网站底部广告代码wordpress栏目设置到导航
  • 温州企业网站开发六安商务网站建设电话
  • 药膳网站建设的目的网页设计代码计算器
  • 电力网站建设wordpress 值班功能
  • 南昌网站建设公司服务o2o网站策划
  • 网站更换域名备案dw做网站的导航栏
  • 东莞网站制作搜索祥奔科技北京诚通新新建设有限公司网站
  • 上虞区建设局网站有哪些网站可以做设计比赛
  • 网站备案后怎么做地图上搜索不到的公司正规吗
  • 受欢迎的做网站八戒网站做推广
  • dw制作asp网站模板网站建设如何上传图片
  • 求网站晚上睡不着2021新闻投稿平台有哪些
  • 电子商务网站建设规划实践成果5年网站续费多少钱
  • 网站推广入口在阿里云做的网站怎么进后台
  • 汝州住房和城乡建设局网站站外推广营销方案
  • 建设网站需要的编程网页结构布局