weixin_51542019 2022-04-09 23:45 采纳率: 75%
浏览 33
已结题

Python/ 代码问题,如何解决?/list

请问如何解决这个问题

自动驾驶汽车

这一年是 2400 年。网约车巨头Suber已经破解了自动驾驶汽车,并拥有一支由n辆汽车组成的车队。 所有的汽车目前都在XX大街(该国唯一的街道,假设这条大街特别长且完全笔直的街道)。 第i辆车目前位于距离街道起点 d[i] 公里的位置。

此外,Suber在XX大街有m个车库。 其中第i个位于距离街道起点 e[i] 公里的位置。每个车库容量无限,可容纳无限多辆自动驾驶汽车;任何汽车都可以存放在任何车库中。

此时发布了降雪警告,Suber必须尽快将所有汽车开到车库。 为了节省电力,他们希望尽量减少汽车行驶的总距离。汽车需要行驶的最小总距离是多少?

Input

Input由两行组成:

第一行包含由单个空格分隔的n个整数。 这些数字指定了list d。
第二行包含 m 个整数,由单个空格分隔。 这些数字指定了list e。

Output

输出一个整数:汽车需要行驶的最小总距离。

限制

1 ≤ n, m ≤ 105
0 ≤ d[i], e[i] ≤ 109

时间限制

您的程序必须在 2 秒内完成任何有效输入的运行。

Sample Input 1

1 0 1
2 5

Sample Output 1

4

Sample1 解释

位置 1、0 和 1 有 3 辆汽车; 以及位置 2 和 5 的两个车库。
唯一的最佳解决方案是将所有汽车开到第一个车库。 这样,位置 1 的两辆车各开 1 公里,另一辆车开 2 公里,总共 4 公里。

Sample Input 2

5 1 10
13 1 7

Sample Output 2

5

我的代码
d = list[map(int, input().split())]
g = list[map(int, input().split())]
n = len(d)

car, i=0,0
while(i<m and car<n):
if abs(d[car]-g[i])<minDistance:
minDistance = abs(d[car]-g[i])
i+=1
else:
totalDistance += minDistance
minDistance = 10**10
i-=1
car+=1
print(totalDistance)
出来的结果不对 请问如何修改

  • 写回答

2条回答 默认 最新

  • 关注

    你题目的解答代码如下:

    d = list(map(int, input().split()))
    g = list(map(int, input().split()))
    g.sort()
    
    n = len(g)
    totalDistance = 0
    for c in d:
        for i in range(n):
            if g[i]>=c:
                break
        if i==0:
            totalDistance += abs(c-g[i])
        else:
            totalDistance += min(abs(c-g[i-1]),abs(c-g[i]))
    print(totalDistance)
    

    img

    如有帮助,请点击我的回答下方的【采纳该答案】按钮帮忙采纳下,谢谢!

    img

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(1条)

报告相同问题?

问题事件

  • 已结题 (查看结题原因) 4月21日
  • 已采纳回答 4月21日
  • 创建了问题 4月9日

悬赏问题

  • ¥15 微信会员卡等级和折扣规则
  • ¥15 微信公众平台自制会员卡可以通过收款码收款码收款进行自动积分吗
  • ¥15 随身WiFi网络灯亮但是没有网络,如何解决?
  • ¥15 gdf格式的脑电数据如何处理matlab
  • ¥20 重新写的代码替换了之后运行hbuliderx就这样了
  • ¥100 监控抖音用户作品更新可以微信公众号提醒
  • ¥15 UE5 如何可以不渲染HDRIBackdrop背景
  • ¥70 2048小游戏毕设项目
  • ¥20 mysql架构,按照姓名分表
  • ¥15 MATLAB实现区间[a,b]上的Gauss-Legendre积分