欢迎访问 生活随笔!

生活随笔

当前位置: 首页 > 编程资源 > 编程问答 >内容正文

编程问答

LeetCode 1953. 你可以工作的最大周数

发布时间:2024/7/5 编程问答 45 豆豆
生活随笔 收集整理的这篇文章主要介绍了 LeetCode 1953. 你可以工作的最大周数 小编觉得挺不错的,现在分享给大家,帮大家做个参考.

文章目录

    • 1. 题目
    • 2. 解题

1. 题目

给你 n 个项目,编号从 0 到 n - 1 。
同时给你一个整数数组 milestones ,其中每个 milestones[i] 表示第 i 个项目中的阶段任务数量。

你可以按下面两个规则参与项目中的工作:

  • 每周,你将会完成 某一个 项目中的 恰好一个 阶段任务。你每周都 必须 工作。
  • 连续的 两周中,你 不能 参与并完成同一个项目中的两个阶段任务。

一旦所有项目中的全部阶段任务都完成,或者仅剩余一个阶段任务都会导致你违反上面的规则,那么你将 停止工作 。注意,由于这些条件的限制,你可能无法完成所有阶段任务。

返回在不违反上面规则的情况下你 最多 能工作多少周。

示例 1: 输入:milestones = [1,2,3] 输出:6 解释:一种可能的情形是: ​​​​-1 周,你参与并完成项目 0 中的一个阶段任务。 -2 周,你参与并完成项目 2 中的一个阶段任务。 -3 周,你参与并完成项目 1 中的一个阶段任务。 -4 周,你参与并完成项目 2 中的一个阶段任务。 -5 周,你参与并完成项目 1 中的一个阶段任务。 -6 周,你参与并完成项目 2 中的一个阶段任务。 总周数是 6 。示例 2: 输入:milestones = [5,2,1] 输出:7 解释:一种可能的情形是: -1 周,你参与并完成项目 0 中的一个阶段任务。 -2 周,你参与并完成项目 1 中的一个阶段任务。 -3 周,你参与并完成项目 0 中的一个阶段任务。 -4 周,你参与并完成项目 1 中的一个阶段任务。 -5 周,你参与并完成项目 0 中的一个阶段任务。 -6 周,你参与并完成项目 2 中的一个阶段任务。 -7 周,你参与并完成项目 0 中的一个阶段任务。 总周数是 7 。 注意,你不能在第 8 周参与完成项目 0 中的最后一个阶段任务,因为这会违反规则。 因此,项目 0 中会有一个阶段任务维持未完成状态。提示: n == milestones.length 1 <= n <= 10^5 1 <= milestones[i] <= 10^9

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/maximum-number-of-weeks-for-which-you-can-work
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

2. 解题

class Solution { // 错误解 [5,7,5,7,9,7] public:long long numberOfWeeks(vector<int>& milestones) {long long ans = 0;priority_queue<int> q(milestones.begin(), milestones.end());while(q.size() > 1){int m1 = q.top();q.pop();int m2 = q.top();q.pop();ans = ans+m2+m2;if(m1-m2>0)q.push(m1-m2);}ans += !q.empty();return ans;} };

参考题解区思路

class Solution { public:long long numberOfWeeks(vector<int>& milestones) {long long sum = accumulate(milestones.begin(), milestones.end(), 0LL);int maxval = *max_element(milestones.begin(), milestones.end());if(maxval > sum-maxval) // 最多的大于剩余的,他自己肯定消耗不完return (sum-maxval)*2+1;return sum; // 否则,可以全部消耗完} };

148 ms 73.7 MB C++


我的CSDN博客地址 https://michael.blog.csdn.net/

长按或扫码关注我的公众号(Michael阿明),一起加油、一起学习进步!

总结

以上是生活随笔为你收集整理的LeetCode 1953. 你可以工作的最大周数的全部内容,希望文章能够帮你解决所遇到的问题。

如果觉得生活随笔网站内容还不错,欢迎将生活随笔推荐给好友。