蓝桥杯每日一练——搬走要石(二分法) python

问题描述
  住在有顶天的天人Tensi对自己的住处很不满。终于有一天她决定把门前碍眼的要石通通丢掉(怒扔要石)。控制要石自然是很容易的事,不过也会消耗灵力。假设搬走一块质量为1的要石会消耗1点灵力,而且由于要石都是连着放置的缘故所以每次除了搬走一颗,也可以搬走连续的任意数量的要石,自然质量是算在一起的。现在Tensi准备最多使用M次灵力,但是她太懒……所以每次只会使用同量的灵力,也因为她太烂,所以也不愿意多花一点灵力……现在很懒的Tensi需要你帮她计算最少一次需要消耗多少灵力,能够在M次内把所有要石都丢到人间去……
输入格式
  第一行两个数N,M,用一个空格分隔。1<=n<=1000,1<=m<=400
  表示一共有N颗要石需要搬走已经Tensi最多发动M次灵力。   接下来包括N 个正整数 0<=ai<=40000
  顺序表示每一颗要石的质量。
输出格式   
   输出一个数T   
  表示Tensi 每次至少消耗T灵力。0<=T<=1000000
  如果无解输出-1.
样例输入
5 3
1 2 1 1 1
样例输出
3
数据规模和约定
  对于100%的数据,1<=n<=1000,1<=m<=400,0<=ai<=40000。   
  保证0<=T<=1000000。

def fun(x):
    count = 1
    sum = 0
    i = 0
    while i < len(stone):   # 用i循环来捡石头
        sum += stone[i]     # 捡起一块石头
        # 如果这是最后一块石头,并且捡的起来(力气够),那就返回真
        if i == len(stone) - 1 and sum <= x:  
            return True
        if sum > x:         # 如果sum > x,也就是力气不够
            sum 
评论 8
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值