题目描述
服务中心的位置记为location,区域由[left,right]表示,服务中心到区域的距离为:
- 如果right < location,则距离为location - right
- 如果location < left,距离为left - location
- 如果left <= location <= right,则距离为0
输入:
第一行,一个整数N表示区域个数。
后面N行,每行两个整数,表示区域的左右起点终点。
输出:
一个整数,表示服务中心位置到所有区域的距离总和的最小值
题目分析
- 输入的区域包含交集
- 经过例子发现规律,距离之和最小的location在输入的所有区间left和right排序后的中间两个数组成的区间上。
- 例如:[1,2],[4,7],[5,20] 排序后为1,2,4,5,7,20,中间的两个数为4,5,则4<=location<=5时,距离最小;[1,3],[2,4],[4,5],[6,20],排序后1,2,3,4,4,5,6,20,中间两个数是4,4,则location=4,距离之和最小,为3
代码实现
size = int(input().strip())
rows = []
datas = []
for i in range(size):
a, b = map(int, input().strip().split(' '))
datas.append(a)
datas.append(b)
rows.append((a, b))
datas.sort()
i = len(datas) // 2 - 1
location = datas[i]
distance = 0
for start, end in rows:
if location > end:
distance += location - end
elif location < start:
distance += start - location
print(distance)