2024-5-16——你可以工作的最大周数

题目来源

力扣每日一题;题序:1953

我的题解

方法一 贪心

首先计算出耗时最长的工作所需周数 longest 与剩余工作所需周数 rest,并比较两者大小。根据比较的结果不同会有两种情况:

  • longest≤rest+1,所有工作都可以完成,返回所有工作的总耗时 longest+rest 作为答案。
  • longest>rest+1,此时无法完成耗时最长的工作。耗时最长的工作最多可以完成 rest+1周,因此最大的工作周数即为 2×rest+1,返回该数作为答案。

时间复杂度:O(n)
空间复杂度:O(1)

public long numberOfWeeks(int[] milestones) {
    long res=0;
    long maxLen=0;
    long restLen=0;
    int n=milestones.length;
    for(int i=0;i<n;i++){
        restLen+=milestones[i];
        maxLen=Math.max(maxLen,milestones[i]);
    }
    restLen-=maxLen;
    //耗时最长的工作无法完成
    //除了耗时最长的工作外还需要的周数+1<耗时最长的工作需要的周数
    if(restLen+1<maxLen)
        return restLen*2+1;
    //所有工作都能完成
    else
        return restLen+maxLen;
}

有任何问题,欢迎评论区交流,欢迎评论区提供其它解题思路(代码),也可以点个赞支持一下作者哈😄~

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

菜菜的小彭

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值