首先暴力做法,声明两个数组记录分别所有的巧克力的长宽,再定义一个变量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)