蓝桥杯 算法提高 ADV-1162 阴谋 python AC

keyword:数组、排序

python 复制代码
n = int(input())
d = {}
for _ in range(n):
    a, b = map(int, input().split())
    if (a in d and d[a] < b) or a not in d:
        d[a] = b
d = sorted(d.items(), key=lambda x: x[0])
ans = 0
l, r = d[0][0], d[0][1]
for i, j in d[1:]:
    if i <= r:
        if j > r:
            r = j
    else:
        ans += r - l
        l, r = i, j
ans += r - l
print(ans)

先存起来排序

每种情况分别判断下一段区间:

--下一段左区间在当前区间内,合并两段区间,更新右区间为两段最大的右区间

--下一段左区间在当前区间外,把当前区间长度累加到变量中,更新左右区间为下一段左右区间

坑点是题目说左闭右闭,实际上是左闭右开

相关推荐
小熳芋21 分钟前
单词搜索- python-dfs&剪枝
算法·深度优先·剪枝
智航GIS33 分钟前
5.1 if语句基础
开发语言·python
Xの哲學33 分钟前
Linux SLAB分配器深度解剖
linux·服务器·网络·算法·边缘计算
bu_shuo37 分钟前
MATLAB中的转置操作及其必要性
开发语言·算法·matlab
华研前沿标杆游学44 分钟前
2026年湖南省工业旅游线路
python
高洁011 小时前
图神经网络初探(2)
人工智能·深度学习·算法·机器学习·transformer
爱装代码的小瓶子1 小时前
算法【c++】二叉树搜索树转换成排序双向链表
c++·算法·链表
思成Codes1 小时前
数据结构:基础线段树——线段树系列(提供模板)
数据结构·算法
APIshop1 小时前
深入解析京东API接口:如何高效获取商品详情与SKU信息
python
94621931zyn61 小时前
备份恢复 - Cordova 与 OpenHarmony 混合开发实战
python