第八届蓝桥杯省赛A/B组 - 分巧克力--Python题解

 首先暴力做法,声明两个数组记录分别所有的巧克力的长宽,再定义一个变量maxlenth记录所有巧克力中最大的边长,之后从maxlenth遍历到1逐个检查是否满足条件,满足直接跳出循环并输出,但是数据大小来到了十的五次方,这么做一定会超时的,拿不到全部的分数。代码如下:

n,k = map(int, input().split())
h = [0] * n
w = [0] * n
maxlenth = 0  #所有饼干的最大的边长
maxlen = 0  #小朋友们可以得到的巧克力的最大边长
for i in range(n):
    h[i], w[i] = map(int, input().split())
    
maxlenth = max(max(h), max(w))#获取已有巧克力最大的边长

#边长为i的方形,依次遍历
for i in range(maxlenth,0,-1):
    sum1 = 0 
    for j in range(n):
        sum1 = sum1 + (h[j]//i)*(w[j]//i)
    if sum1 >= k:
        maxlen = i
        break
print(maxlen)

通过二分算法可以将其优化,因为可以发现,对于小朋友可以获得的巧克力的最大边长这个值maxlen,属于一个有序数列,最大边长左边的数全部满足要求,最大边长右边的数全部不满足需求。代码如下:

import os
import sys

# 请在此输入您的代码

N = 100005
h = [0] * N
w = [0] * N

def check(a):
    num = 0  # 记录分成长度为 a 的巧克力数量
    for i in range(n):
        num += (w[i] // a) * (h[i] // a)  # 每一大块可以分成的边长为 a 的巧克力数量
        if num >= k:
            return True  # 大于要求数量,返回真
    return False

n, k = map(int, input().split())
for i in range(n):
    h[i], w[i] = map(int, input().split())

l, r = 1, 100000
while l < r:
    mid = (l + r) // 2
    if check(mid):
        l = mid + 1
    else:
        r = mid

print(r - 1)

  • 12
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值