蓝桥杯 算法提高 ADV-1164 和谐宿舍 python AC

贪心,二分

同类型题:蓝桥杯 算法提高 ADV-1175 打包

python 复制代码
def judge(x):
    wood = 0
    max_val = 0
    ans_len = 0
    for i in ll:
        if i > x:
            return False
        elif max(max_val, i) * (ans_len + 1) <= x:
            max_val = max(max_val, i)
            ans_len += 1
        else:
            wood += 1
            max_val = i
            ans_len = 1
    if ans_len:
        wood += 1
    return wood <= m


n, m = map(int, input().split())
ll = list(map(int, input().split()))
l, r = 0, max(ll) * len(ll)
while l < r:
    mid = (l + r) // 2
    if judge(mid):
        r = mid
    else:
        l = mid + 1
print(l)

函数遍历中加入了一个剪枝,判断当单个画大于木板时直接返回false,否则代码会直接判断加入新元素后的大小

相关推荐
2301_8101609510 小时前
C++中的策略模式进阶
开发语言·c++·算法
keep intensify10 小时前
二叉树的直径
数据结构·算法·深度优先
gCode Teacher 格码致知10 小时前
Javascript及Python提高:将对象的键值对转换为数组元素的方式以及两种语言的对比-由Deepseek产生
javascript·python
keep intensify10 小时前
单源最短路径
数据结构·c++·算法
2401_8735449210 小时前
分布式缓存一致性
开发语言·c++·算法
香芋超新星10 小时前
反转字符串中的小写字母
算法
浔川python社10 小时前
《C++ 小程序编写系列》(合集)
python
阿钱真强道10 小时前
37 Python 时序和文本:词袋模型 BoW 和 TF-IDF 到底怎么理解?
python·nlp·tf-idf·文本向量化·词袋模型·bow
篮l球场11 小时前
数组中的第K个最大元素
数据结构·算法·leetcode
2401_8735449211 小时前
使用Fabric自动化你的部署流程
jvm·数据库·python