算法-二分与差分-503.借教室

题目

思路

  1. 代码不超时:限制在10的8次方以内;线段树能处理的数据上限是10^5
  2. 二分:具有二段性,第一个订单不满足,后面的订单也不用去考虑
  3. 差分(前缀和的逆运算):题目的要求是将一个区间整体减去一个数,最终去判断是否存在某个数小于零
  4. 二分完之后利用差分将前面若干个订单判断一遍,如果前面存在订单小于0,说明不满足
  5. AcWing 503. 借教室(寒假每日一题) - AcWing

代码

python 复制代码
n, m = map(int, input().split())
r = [0] + list(map(int, input().split()))
d = [0] * (m+5)  
s = [0] * (m+5)  
t = [0] * (m+5)  
b = [] 

def check(mid):
    b = [0] * (n+5)  # 将 b 初始化为与 r 相同长度的列表,并全部填充为 0
    for i in range(1, n+1):
        b[i] = r[i] - r[i-1]  # 差分数组的初始化
    for i in range(1, mid+1):  # 处理前 mid 个订单
        b[s[i]] -= d[i]  # 有订单之后,区间的值要减少 d[i]
        b[t[i] + 1] += d[i]  # 差分的基本操作
    for i in range(1, n+1):  # 求差分数组的前缀和,相当于求原数组
        b[i] += b[i-1]
        if b[i] < 0:
            return False  # 说明订单不能满足
    return True

for i in range(1, m+1):
    d[i], s[i], t[i] = map(int, input().split())

L, R = 1, m
while L < R:
    mid = (L + R) >> 1
    if check(mid)==False:
        R = mid
    else:
        L = mid + 1  
if check(m) :
    print("0")
else :
    print("-1")
    print(R)
相关推荐
想进个大厂1 分钟前
代码随想录day63 64 65 66 图论08 09 10 11
c++·算法·图论
云泽8083 分钟前
蓝桥杯算法精讲:双指针算法四大经典例题深度剖析
算法·职场和发展·蓝桥杯
witAI6 分钟前
**Kimi小说灵感2025推荐,从零到一的创意激发指南**
人工智能·python
小龙报14 分钟前
【算法通关指南:算法基础篇】二分算法: 1.A-B 数对 2.烦恼的高考志愿
c语言·开发语言·数据结构·c++·vscode·算法·二分
yong999017 分钟前
NNDA、PDA、JPDA、IMM数据关联算法MATLAB实现
开发语言·算法·matlab
罗湖老棍子20 分钟前
加分二叉树(信息学奥赛一本通- P1580)(洛谷-P1040)
算法·区间dp·区间动态规划
飞Link22 分钟前
深度解析:基于专家的监管方法(Expert-Based Supervision)在复杂系统中的应用
python·数据挖掘·回归
Shining059625 分钟前
Triton & 九齿系列《Triton 练气术》
开发语言·人工智能·python·学习·其他·infinitensor
天远Date Lab30 分钟前
天远企业司法认证API实战:Python构建企业级供应链合规审查防火墙
大数据·开发语言·网络·python