贪心 汽车加油 java_贪心算法解汽车加油站问题
一辆汽车加满油后可行驶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_贪心算法解汽车加油站问题相关推荐
- 汽车加油问题--贪心算法(算法设计与分析)
7-1 汽车加油问题 题目来源:王晓东<算法设计与分析> 一辆汽车加满油后可行驶 n公里.旅途中有若干个加油站.设计一个有效算法,指出应 在哪些加油站停靠加油,使沿途加油次数最少. 输入格 ...
- 汽车加油问题 --贪心算法
问题描述 一辆汽车加满油后可行驶nkm .旅途中有若干个加油站.设计一个有效算法,指出应在哪些加油站停靠加油,使沿途加油次数最少. 编程任务 对于给定的n和k个加油站位置,编程计算最少加油次数. 数据 ...
- 汽车加油问题 贪心算法 Java(详细注释)
目录 一.问题描述 二.分析过程 三.参考代码及运行结果 一.问题描述 二.分析过程 i :第i个加油站 i = 0:出发地 i = k:目的地(共 k+1 个站,由问题知,k = 5) x[i] : ...
- 汽车加油问题贪心算法c语言,汽车加油问题之贪心算法(全面分析)
一辆汽车加满油后可以行驶N千米.旅途中有若干个加油站.指出若要使沿途的加油次数最少,设计一个有 效的算法,指出应在那些加油站停靠加油.给出N,并以数组的形式给出加油站的个数及相邻距离,指出若要使沿途的 ...
- 汽车加油问题--贪心算法
一辆汽车加满油后可行驶n公里.旅途中有若干个加油站.设计一个有效算法,指出应 在哪些加油站停靠加油,使沿途加油次数最少.对于给定的n(n <= 5000)和k(k <= 1000)个加油站 ...
- 算法设计与分析——贪心算法——汽车加油问题
汽车加油问题:一辆汽车加满油后可行驶n公里,旅途中有若干个加油站,两加油站间距离不超n 公里,起点离第一个加油站距离及最后一个加油站离终点距离也不超过n公里.算法给出应在哪些加油站停靠加油,使沿途加油 ...
- 贪心算法——汽车加油问题
一辆汽车加满油后可行驶n公里.旅途中有若干个加油站.设计一个有效算法,指出应在哪些加油站停靠加油,使沿途加油次数最少. 输入:第1行两个正整数n和k,表示汽车加满油后可行驶n 公里,且旅途中有k个加油 ...
- C++贪心实现汽车加油问题
一.实验目的 1.掌握基于贪心的算法求解汽车加油问题的原理和贪心性质的证明. 2.掌握汽车加油问题贪心算法正确性的推导过程和设计原理. 3.掌握基于贪心的算法汽车加油问题函数的具体步骤. 4.具备运用 ...
- 【贪心算法】虚拟汽车加油问题
算法实现题 4-9 虚拟汽车加油问题 问题描述: 一辆虚拟汽车加满油后可以行驶n km.途中有若干个加油站.设计一个有效的算法,指出应在那个加油站停靠加油,使沿途加油次数最少. 算法设计: 给定n和k ...
- 「贪心算法」虚拟汽车加油问题
> 问题描述 一辆虚拟汽车加满油后可行驶 n km.旅途中有若干加油站.设计一个有效算法,指出应在哪些加油站停靠加油,使沿途加油次数最少,计算最少加油次数. > 数据输入 终端输入正整数 ...
最新文章
- 什么才是真正的L3自动驾驶?
- C++中定义对象的语法,带括号与不带括号有什么区别?
- qemu+linux+x86+64,qemu以64位跟32位的方式跑busybox
- java 线程参数 用final,JAVA 关于final修饰变量参数
- Step By Step (zz from UESTC)
- 使用UE4发布安卓平台游戏
- 华为鸿蒙系统是物联网,华为鸿蒙系统官宣!谷歌工程师直接懵了,硅谷感慨:中国人太厉害...
- element el-upload上传图片完成后隐藏上传
- 表单验证 靠name获取
- ci mysql空闲连接回收_数据库连接空闲回收问题 CommunicationsException: Communications link failure...
- 乐优商城项目实战系列笔记1-项目搭建
- PPT文件太大?如何压缩PPT?这几招帮你搞定
- 快递查询API接口对接案例(顺丰、圆通、中通、德邦、天天)
- Enterprise Architect综合建模平台
- chrome浏览器模拟慢网速环境
- Play Framework
- warcraft 3 经典语句之月之女祭司(Priestess of the moon)
- 项目分享-限流框架的实现
- UE4 C++入门之路1-C++和蓝图的关系和介绍
- (12)筋斗云案例(导航栏醒目显示跟随)
热门文章
- Node.js开发入门—使用http访问外部世界
- Nginx-配置大全
- 帝国栏目导航点击显示不同样式的实现
- WSJ在隐私是否真的那么可怕
- PD QC充电器XP06诱骗取电9V 12V 15V 20V原理
- 2020年408真题_2020年港澳台联考真题——英语!
- C++ “电子宠物游戏”
- oracle语句整理,Oracle 维护常用SQL语句整理
- python做一个qq聊天窗口_python实现qq聊天(带界面)
- 2进制 , 8进制 , 10进制 , 16进制 , 介绍 及 相互转换 及 快速转换的方法