蓝桥杯 算法提高 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,否则代码会直接判断加入新元素后的大小

相关推荐
cui_ruicheng2 分钟前
C++数据结构进阶:哈希表实现
数据结构·c++·算法·哈希算法·散列表
qingcyb3 分钟前
重复 id 对应的多个对象
开发语言·python
mingshili3 分钟前
[python] asyncio常规操作记录
python·async
chushiyunen6 分钟前
python edge-tts实现tts文本转语音、音频
数据库·python·音视频
嫂子的姐夫12 分钟前
040-spiderbuf第C8题
javascript·爬虫·python·js逆向·逆向
li星野13 分钟前
[特殊字符] 模拟试卷一:C++核心与系统基础(90分钟)答案版
开发语言·c++·算法
江上清风山间明月15 分钟前
python将dtso文件转换成dtbo文件
python·dts·dtso
天下无贼!20 分钟前
【Python】2026版——FastAPI 框架快速搭建后端服务
开发语言·前端·后端·python·aigc·fastapi
2501_9454235423 分钟前
游戏与图形界面(GUI)
jvm·数据库·python
二进制星轨27 分钟前
leecode-283-移动零-算法题解
算法