lilili07 2022-05-07 11:39 采纳率: 72.7%
浏览 163
已结题

python 给汽车加油 贪心算法

一辆汽车加满油后可行驶 d公里。旅途中有若干个加油站,指出应在哪些加油站停靠加油(每次加油都加满),使沿途加油次数最少。

第一行有 2 个正整数d和 k(k<=1000 ),表示汽车加满油后可行驶d公里,且旅途中有 k个加油站。 第二行有 k个整数,表示第 k 个加油站与第k-1 个加油站之间的距离。 第 0 个加油站表示出发地,汽车已加满油(到达最后一个加油站则认为到达目的地)。

输出:
输出最少加油次数。如果无法到达目的地,则输出“No Solution!”。

输入:
7 7
1 2 3 4 5 1 6
输出:
3

  • 写回答

3条回答 默认 最新

  • 关注

    img

    
    n, k = map(int, input().split())
    d = list(map(int, input().split()))
    c = 0  # 初始化加油次数
    now = n  # 初始化当前油量
    for i in range(k ):  # 开始旅途~
        if now < d[i]:  # 判断当前油量是否可以到达下一个加油站
            c += 1  # 如果无法到达,则需要加油。加油次数+1
            now = n  # 重新初始化油量
        now -= d[i]  # 减去到达下一站所需油量
        if now < 0:  # 判断此时当前油量
            c = 'No Solution'  # 当前油量为负,说明无法到达下一站,输出无解
            break  # 不能再愉快的旅行了
    print(c)  # 输出结果
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 5月15日
  • 已采纳回答 5月7日
  • 修改了问题 5月7日
  • 修改了问题 5月7日
  • 展开全部

悬赏问题

  • ¥15 网络科学导论,网络控制
  • ¥15 metadata提取的PDF元数据,如何转换为一个Excel
  • ¥15 关于arduino编程toCharArray()函数的使用
  • ¥100 vc++混合CEF采用CLR方式编译报错
  • ¥15 coze 的插件输入飞书多维表格 app_token 后一直显示错误,如何解决?
  • ¥15 vite+vue3+plyr播放本地public文件夹下视频无法加载
  • ¥15 c#逐行读取txt文本,但是每一行里面数据之间空格数量不同
  • ¥50 如何openEuler 22.03上安装配置drbd
  • ¥20 ING91680C BLE5.3 芯片怎么实现串口收发数据
  • ¥15 无线连接树莓派,无法执行update,如何解决?(相关搜索:软件下载)