算法第十天-在D天之内送达包裹的能力
在D天之内送达包裹的能力
题目要求

 
解题思路
二分解法(精确边界)
 假定[D天内送完所有包裹的最低运力]为 
     
      
       
       
         a 
        
       
         n 
        
       
         s 
        
       
      
        ans 
       
      
    ans,那么在以 
     
      
       
       
         a 
        
       
         n 
        
       
         s 
        
       
      
        ans 
       
      
    ans为分割点的数轴上具有[二段性]:
- 数值范围在 ( ? ∞ , a n s ) (-∞,ans) (?∞,ans)的运力必然[不满足]D天内运送完所有包裹的要求
- 数值范围在 ( a n s , ∞ ) (ans,∞) (ans,∞)的运力必然[满足]D天内送完所有包裹的要求
即我们可以通过[二分]来找到恰好满足D天内运送完所有包裹的分割点 
      
       
        
        
          a 
         
        
          n 
         
        
          s 
         
        
       
         ans 
        
       
     ans
 接下来我们要确定二分的范围,由于不存在包裹拆分的情况,考虑如下两种边界情况:
- 理论最低运力:只确保所有包裹能够被运送,自然也包括重量最大的包裹,此时理论最低运力为 m a x max max, m a x max max为数组 w e i g h t s weights weights中的最大值
- 理论最高运力:使得所有的包裹能够被运送,自然也包括重量最大的包裹,此时理论最低运力为 s u m sum sum, s u m sum sum为数组 w e i g h t s weights weights的总和。
因此我们可以确定二分的范围为 [ m a x , s u m ] [max,sum] [max,sum]
代码
class Solution:
    def shipWithinDays(self, weights: List[int], D: int) -> int:
        max_m,sum_m = max(weights),sum(weights)
        l,r = max(max_m,sum_m//D),sum_m
        while l<r:
            mid = (l+r)>>1
            if self.check(weights,mid,D):
                r=mid
            else:
                l=mid+1
        return r
    def check(self, ws, t, d):
        n = len(ws)
        i = cnt = 1
        total = ws[0]
        while i<n:
            while i<n and total + ws[i] <=t:
                total += ws[i]
                i +=1
            total =0
            cnt +=1
        return cnt -1 <= d
复杂度分析
时间复杂度: 
     
      
       
       
         O 
        
       
         ( 
        
       
         n 
        
       
         l 
        
       
         o 
        
       
         g 
        
       
         ( 
        
       
         ∑ 
        
       
         w 
        
       
         s 
        
       
         [ 
        
       
         i 
        
       
         ] 
        
       
         ) 
        
       
         ) 
        
       
         ) 
        
       
      
        O(nlog(∑ ws[i]))) 
       
      
    O(nlog(∑ws[i]))),check函数复杂度为 
     
      
       
       
         O 
        
       
         ( 
        
       
         n 
        
       
         ) 
        
       
      
        O(n) 
       
      
    O(n)
 空间复杂度: 
     
      
       
       
         O 
        
       
         ( 
        
       
         1 
        
       
         ) 
        
       
      
        O(1) 
       
      
    O(1)
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!