服务中心选址问题

文章讨论了如何通过编程解决服务中心选址问题,确定位置能使服务中心到所有区域的距离总和最小。关键在于对输入区域进行排序,服务中心位于所有区间的中间位置,或者在相交区间中靠近较小端点。提供了示例代码实现这一逻辑。
摘要由CSDN通过智能技术生成

服务中心选址问题

题目描述

服务中心的位置记为location,区域由[left,right]表示,服务中心到区域的距离为:

  1. 如果right < location,则距离为location - right
  2. 如果location < left,距离为left - location
  3. 如果left <= location <= right,则距离为0

输入:
第一行,一个整数N表示区域个数。
后面N行,每行两个整数,表示区域的左右起点终点。

输出:
一个整数,表示服务中心位置到所有区域的距离总和的最小值

题目分析

  1. 输入的区域包含交集
  2. 经过例子发现规律,距离之和最小的location在输入的所有区间left和right排序后的中间两个数组成的区间上。
  3. 例如:[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)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值