leetcode1953_go_你可以工作的最大周数

题目

给你 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 <= 105

1 <= milestones[i] <= 109

解题思路分析

1、遍历;时间复杂度O(n),空间复杂度O(1)

leetcode1953_go_你可以工作的最大周数

func numberOfWeeks(milestones []int) int64 {
   var maxCount int64
   var sum int64
   for i := 0; i < len(milestones); i++ {
      if int64(milestones[i]) > maxCount {
         maxCount = int64(milestones[i])
      }
      sum = sum + int64(milestones[i])
   }
   if maxCount > (sum+1)/2 {
      return (sum-maxCount)*2 + 1
   }
   return sum
}

总结

Medium题目,由于本题数据范围问题,使用堆容易超时;题目思路基本同

leetcode 767.重构字符串、

leetcode 1054.距离相等的条形码

展开阅读全文

页面更新:2024-05-08

标签:本题   都会   工作   条形码   整数   数组   示例   字符串   剩余   情形   题目   规则   阶段   两个   项目   科技

1 2 3 4 5

上滑加载更多 ↓
推荐阅读:
友情链接:
更多:

本站资料均由网友自行发布提供,仅用于学习交流。如有版权问题,请与我联系,QQ:4156828  

© CopyRight 2020-2024 All Rights Reserved. Powered By 71396.com 闽ICP备11008920号-4
闽公网安备35020302034903号

Top