博客
关于我
一维差分小总结
阅读量:369 次
发布时间:2019-03-04

本文共 1480 字,大约阅读时间需要 4 分钟。

????????????????????????????????????????????????????????????????????

????

  • ????????????????????????????????????(l, r)???????????1???l???1???r+1?
  • ????????????????????????????????????????????
  • ??????????????????????????????????????????????????
  • ???????????????????????????????????
  • ????

    def main():    import sys    input = sys.stdin.read    data = input().split()    idx = 0    n = int(data[idx])    idx += 1    m = int(data[idx])    idx += 1        queries = []    for _ in range(m):        l = int(data[idx])        idx += 1        r = int(data[idx])        idx += 1        queries.append((l, r))        diff = [0] * (n + 2)    for l, r in queries:        diff[l] += 1        if r + 1 <= n:            diff[r + 1] -= 1        freq = [0] * (n + 1)    for i in range(1, n + 1):        freq[i] = diff[i]        freq.sort(reverse=True)        a = [0] * (n + 1)    current = n    for i in range(1, n + 1):        if freq[i] == 0:            a[i] = 0        else:            a[i] = current            current -= 1        pre = [0] * (n + 1)    for i in range(1, n + 1):        pre[i] = pre[i - 1] + a[i]        total = 0    for l, r in queries:        total += pre[r] - pre[l - 1]        print(total)if __name__ == "__main__":    main()

    ????

  • ???????sys.stdin.read?????????????n?m?
  • ?????????????????????????
  • ?????????????????????????
  • ????????????????????????????????????
  • ????????????????????????
  • ???????????????????????
  • ?????????????????????????
  • ????????????????????????????????????????????

    转载地址:http://iryg.baihongyu.com/

    你可能感兴趣的文章
    oracle 中的 CONCAT,substring ,MINUS 用法
    查看>>
    Oracle 中的 decode
    查看>>
    oracle 中表一对多取多方的最新的一条数据
    查看>>
    oracle 使用 PL/SQL Developer创建表并插入单条、多条数据
    查看>>
    oracle 使用leading, use_nl, rownum调优
    查看>>
    oracle 修改字段类型方法
    查看>>
    Oracle 修改数据库表数据提交之后进行回滚
    查看>>
    UML-总结
    查看>>
    oracle 内存参数示意图
    查看>>
    Oracle 写存储过程的一个模板还有一些基本的知识点
    查看>>
    UML- 配置图(部署图)
    查看>>
    oracle 切割字符串加引号_使用Clean() 去掉由函数自动生成的字符串中的双引号...
    查看>>
    Oracle 创建 DBLink 的方法
    查看>>
    oracle 创建job
    查看>>
    oracle 创建一个用户,只能访问指定的对象
    查看>>
    oracle 创建双向备份,Materialized View 物化视图实现 Oracle 表双向同步
    查看>>
    oracle 创建字段自增长——两种实现方式汇总
    查看>>
    Oracle 升级10.2.0.5.4 OPatch 报错Patch 12419392 Optional component(s) missing 解决方法
    查看>>
    oracle 去重
    查看>>
    oracle 可传输的表空间:rman
    查看>>