前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >LeetCode 1953. 你可以工作的最大周数

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

作者头像
Michael阿明
发布2021-09-06 11:24:46
4790
发布2021-09-06 11:24:46
举报
文章被收录于专栏:Michael阿明学习之路

文章目录

1. 题目

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

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

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

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

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

代码语言:javascript
复制
示例 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. 解题

代码语言:javascript
复制
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;
    }
};

参考题解区思路

代码语言:javascript
复制
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阿明),一起加油、一起学习进步

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2021/08/01 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 文章目录
  • 1. 题目
  • 2. 解题
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档