一辆汽车加满油后可行驶n公里。旅途中有若干个加油站。设计一个有效算法,指出应在哪些加油站停靠加油,使沿途加油次数最少。对于给定的n(n <= 5000)和k(k <= 1000)个加油站位置,编程计算最少加油次数。并证明算法能产生一个最优解。

要求:

输入:第一行有2个正整数n和k,表示汽车加满油后可行驶n公里,且旅途中有k个加油站。接下来的1 行中,有k+1 个整数,表示第k个加油站与第k-1 个加油站之间的距离。第0 个加油站表示出发地,汽车已加满油。第k+1 个加油站表示目的地。

输出:输出编程计算出的最少加油次数。如果无法到达目的地,则输出”NoSolution”。

思路:

汽车行驶过程中,应走到自己能走到并且离自己最远的那个加油站,在那个加油站加油后再按照同样的方法贪心

具体算法:

先检测各加油站之间的距离,若发现其中有一个距离大于汽车加满油能跑的距离,则输出no solution。否则,对加油站间的距离进行逐个扫描,尽量选择往远处走,不能走了就让num++,最终统计出来的num便是最少的加油站数

#include

using namespace std;

void greedy(int d[],int n,int k) {

int num = 0;

for(int i = 0;i <= k;i++) {     //先判断是否都能到达

if(d[i] > n) {

cout<

return;

}

}

for(int i = 0,s = 0;i <= k;i++) {

s += d[i];

if(s > n) {

num++;

s = d[i];

}

}

cout<

}

int main()

{

int i,n,k;

int d[1000];

cin>>n>>k;

for(i=0;i=k;i++){

cin>>d[i];

}

greedy(d,n,k);

cout << "Hello world!" << endl;

return 0;

}

贪心 汽车加油 java_贪心算法解汽车加油站问题相关推荐

  1. 汽车加油问题--贪心算法(算法设计与分析)

    7-1 汽车加油问题 题目来源:王晓东<算法设计与分析> 一辆汽车加满油后可行驶 n公里.旅途中有若干个加油站.设计一个有效算法,指出应 在哪些加油站停靠加油,使沿途加油次数最少. 输入格 ...

  2. 汽车加油问题 --贪心算法

    问题描述 一辆汽车加满油后可行驶nkm .旅途中有若干个加油站.设计一个有效算法,指出应在哪些加油站停靠加油,使沿途加油次数最少. 编程任务 对于给定的n和k个加油站位置,编程计算最少加油次数. 数据 ...

  3. 汽车加油问题 贪心算法 Java(详细注释)

    目录 一.问题描述 二.分析过程 三.参考代码及运行结果 一.问题描述 二.分析过程 i :第i个加油站 i = 0:出发地 i = k:目的地(共 k+1 个站,由问题知,k = 5) x[i] : ...

  4. 汽车加油问题贪心算法c语言,汽车加油问题之贪心算法(全面分析)

    一辆汽车加满油后可以行驶N千米.旅途中有若干个加油站.指出若要使沿途的加油次数最少,设计一个有 效的算法,指出应在那些加油站停靠加油.给出N,并以数组的形式给出加油站的个数及相邻距离,指出若要使沿途的 ...

  5. 汽车加油问题--贪心算法

    一辆汽车加满油后可行驶n公里.旅途中有若干个加油站.设计一个有效算法,指出应 在哪些加油站停靠加油,使沿途加油次数最少.对于给定的n(n <= 5000)和k(k <= 1000)个加油站 ...

  6. 算法设计与分析——贪心算法——汽车加油问题

    汽车加油问题:一辆汽车加满油后可行驶n公里,旅途中有若干个加油站,两加油站间距离不超n 公里,起点离第一个加油站距离及最后一个加油站离终点距离也不超过n公里.算法给出应在哪些加油站停靠加油,使沿途加油 ...

  7. 贪心算法——汽车加油问题

    一辆汽车加满油后可行驶n公里.旅途中有若干个加油站.设计一个有效算法,指出应在哪些加油站停靠加油,使沿途加油次数最少. 输入:第1行两个正整数n和k,表示汽车加满油后可行驶n 公里,且旅途中有k个加油 ...

  8. C++贪心实现汽车加油问题

    一.实验目的 1.掌握基于贪心的算法求解汽车加油问题的原理和贪心性质的证明. 2.掌握汽车加油问题贪心算法正确性的推导过程和设计原理. 3.掌握基于贪心的算法汽车加油问题函数的具体步骤. 4.具备运用 ...

  9. 【贪心算法】虚拟汽车加油问题

    算法实现题 4-9 虚拟汽车加油问题 问题描述: 一辆虚拟汽车加满油后可以行驶n km.途中有若干个加油站.设计一个有效的算法,指出应在那个加油站停靠加油,使沿途加油次数最少. 算法设计: 给定n和k ...

  10. 「贪心算法」虚拟汽车加油问题

    > 问题描述 一辆虚拟汽车加满油后可行驶 n km.旅途中有若干加油站.设计一个有效算法,指出应在哪些加油站停靠加油,使沿途加油次数最少,计算最少加油次数. > 数据输入 终端输入正整数 ...

最新文章

  1. 什么才是真正的L3自动驾驶?
  2. C++中定义对象的语法,带括号与不带括号有什么区别?
  3. qemu+linux+x86+64,qemu以64位跟32位的方式跑busybox
  4. java 线程参数 用final,JAVA 关于final修饰变量参数
  5. Step By Step (zz from UESTC)
  6. 使用UE4发布安卓平台游戏
  7. 华为鸿蒙系统是物联网,华为鸿蒙系统官宣!谷歌工程师直接懵了,硅谷感慨:中国人太厉害...
  8. element el-upload上传图片完成后隐藏上传
  9. 表单验证 靠name获取
  10. ci mysql空闲连接回收_数据库连接空闲回收问题 CommunicationsException: Communications link failure...
  11. 乐优商城项目实战系列笔记1-项目搭建
  12. PPT文件太大?如何压缩PPT?这几招帮你搞定
  13. 快递查询API接口对接案例(顺丰、圆通、中通、德邦、天天)
  14. Enterprise Architect综合建模平台
  15. chrome浏览器模拟慢网速环境
  16. Play Framework
  17. warcraft 3 经典语句之月之女祭司(Priestess of the moon)
  18. 项目分享-限流框架的实现
  19. UE4 C++入门之路1-C++和蓝图的关系和介绍
  20. (12)筋斗云案例(导航栏醒目显示跟随)

热门文章

  1. Node.js开发入门—使用http访问外部世界
  2. Nginx-配置大全
  3. 帝国栏目导航点击显示不同样式的实现
  4. WSJ在隐私是否真的那么可怕
  5. PD QC充电器XP06诱骗取电9V 12V 15V 20V原理
  6. 2020年408真题_2020年港澳台联考真题——英语!
  7. C++ “电子宠物游戏”
  8. oracle语句整理,Oracle 维护常用SQL语句整理
  9. python做一个qq聊天窗口_python实现qq聊天(带界面)
  10. 2进制 , 8进制 , 10进制 , 16进制 , 介绍 及 相互转换 及 快速转换的方法