`
microapple
  • 浏览: 15840 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

汽车加油问题(停靠最少的加油站)

 
阅读更多

    (一) 问题描述

    一辆汽车加满油后可以行驶N千米。旅途中有若干个加油站。指出若要使沿途的加油次数最少,设计一个有效的算法,指出应在那些加油站停靠加油。

    给出N,并以数组的形式给出加油站的个数及相邻距离,指出若要使沿途的加油次数最少,设计一个有效的算法,指出应在那些加油站停靠加油。要求:算法执行的速度越快越好。

    (二) 问题分析(前提行驶前车里加满油)

    对于这个问题我们有以下几种情况:设加油次数为k,每个加油站间距离为a[i];i=0,1,2,3……n

    1.始点到终点的距离小于N,则加油次数k=0;

    2.始点到终点的距离大于N,

    A  加油站间的距离相等,即a[i]=a[j]=L=N,则加油次数最少k=n;

    B  加油站间的距离相等,即a[i]=a[j]=L>N,则不可能到达终点;

    C  加油站间的距离相等,即a[i]=a[j]=L<N,则加油次数k=n/N(n%N==0)或k=[n/N]+1(n%N!=0);(没看懂,有问题吧,是否应该是(n+2)/(N/L))

    D  加油站间的距离不相等,即a[i]!=a[j],则加油次数k通过以下算法求解。

    (三)算法描述

    贪心算法的基本思想

    该题目求加油最少次数,即求最优解的问题,可分成几个步骤,一般来说,每个步骤的最优解不一定是整个问题的最优解,然而对于有些问题,局部贪心可以得到全局的最优解。贪心算法将问题的求解过程看作是一系列选择,从问题的某一个初始解出发,向给定目标推进。推进的每一阶段不是依据某一个固定的递推式,而是在每一个阶段都看上去是一个最优的决策(在一定的标准下)。不断地将问题实例归纳为更小的相似的子问题,并期望做出的局部最优的选择产生一个全局得最优解。

    贪心算法的适用的问题

    贪心算法适用的问题必须满足两个属性:

    (1)   贪心性质:整体的最优解可通过一系列局部最优解达到,并且每次的选择可以依赖以前做出的选择,但不能依赖于以后的选择。

    (2)   最优子结构:问题的整体最优解包含着它的子问题的最优解。

    贪心算法的基本步骤

    (1)   分解:将原问题分解为若干相互独立的阶段。

    (2)   解决:对于每一个阶段求局部的最优解。

    (3)   合并:将各个阶段的解合并为原问题的解。

    [问题分析]

    由于汽车是由始向终点方向开的,我们最大的麻烦就是不知道在哪个加油站加油可以使我们既可以到达终点又可以使我们加油次数最少。

    提出问题是解决的开始.为了着手解决遇到的困难,取得最优方案。我们可以假设不到万不得已我们不加油,即除非我们油箱里的油不足以开到下一个加油站,我们才加一次油。在局部找到一个最优的解。却每加一次油我们可以看作是一个新的起点,用相同的递归方法进行下去。最终将各个阶段的最优解合并为原问题的解得到我们原问题的求解。

    加油站贪心算法设计(C):

    include<math.h>
    include<studio.h>
    int add(int b[ ],int m,int n)
    {  //求一个从m到n的数列的和
    int sb;
    for(int i=m;i<n;i++) sb+=b[i];
    return sb;
    }
    int Tanxin(int a[n], int N)  //a[n]表示加油站的个数,N为加满油能行驶的最远距离
    {
    int b[n];  //若在a[i]加油站加油,则b[i]为1,否则为0
    int m=0;
    if(a[i]>N) return ERROR;  //如果某相邻的两个加油站间的距离大于N,则不能到达终点
    if(add(a[i], 0, n)<N)
    { //如果这段距离小于N,则不需要加油
    b[i]=0;
    return add(b[i],0,n);
    }
    if(a[i]==a[j]&&a[i]==N)
    { //如果每相邻的两个加油站间的距离都是N,则每个加油站都需要加油
    b[i]=1;
    return add(b[i],0,n);
    }
    if(a[i]==a[j]&&a[i]<N)
    { //如果每相邻的两个加油站间的距离相等且都小于N
    if( add(a[i],m,k) < N && add(a[i],m,k+1) > N )
    {
    b[k]=1;
    m+=k;
    }
    return add(b[i],0,n);
    }
    if(a[i]!=a[j])
    { //如果每相邻的两个加油站间的距离不相等且都小于N
    if( add(a[i],m,k) < N && add(a[i],m,k+1) > N )
    {
    b[k]=1;
    m+=k;
    }
    return add(b[i],0,n);
    }
    viod main( )
    {
    int a[ ];
    scanf("%d",a);
    scanf("/n");
    scanf("/d",&N);
    Tanxin(a[ ],0,n);
    }

    贪心算法正确性证明:

    贪心选择性质

    所谓贪心选择性质是指所求问题的整体最优解可以通过一系列局部最优的选择,即贪心选择来达到。对于一个具体的问题,要确定它是否具有贪心性质,我们必须证明每一步所作的贪心选择最终导致问题的一个整体最优解。该题设在加满油后可行驶的N千米这段路程上任取两个加油站A、B,且A距离始点比B距离始点近,则若在B加油不能到达终点那么在A加油一定不能到达终点,因为m+N<n+N,即在B点加油可行驶的路程比在A点加油可行驶的路程要长n-m千米,所以只要终点不在B、C之间且在C的右边的话,根据贪心选择,为使加油次数最少就会选择距离加满油得点远一些的加油站去加油,因此,加油次数最少满足贪心选择性质。

    最优子结构性质:

    当一个问题大的最优解包含着它的子问题的最优解时,称该问题具有最优子结构性质。由于(b[1],b[2],……b[n])是这段路程加油次数最少的一个满足贪心选择性质的最优解,则易知若在第一个加油站加油时,b[1]=1,则(b[2],b[3],……b[n])是从 a[2]到a[n]这段路程上加油次数最少且这段路程上的加油站个数为(a[2],a[3],……a[n])的最优解,即每次汽车中剩下的油不能在行驶到下一个加油站时我们才在这个加油站加一次油,每个过程从加油开始行驶到再次加油满足贪心且每一次加油后相当于与起点具有相同的条件,每个过程都是相同且独立,也就是说加油次数最少具有最优子结构性质。

    贪心算法时间复杂度分析

    由于若想知道该在哪个加油站加油就必须遍历所有的加油站,且不需要重复遍历,所以时间复杂度为O(n)。

分享到:
评论

相关推荐

    汽车加油问题 对于给定的n和k个加油站位置,编程计算最少加油次数。

    设计一个有效算法,指出应在哪些加油站停靠加油,使沿途加油次数最少。并证明算法能产生一个最优解。 编程任务: 对于给定的n和k个加油站位置,编程计算最少加油次数。 Input 输入由多组测试数据组成。 每组...

    汽车加油问题+算法设计

    问题描述:一辆汽车加满油后可行驶 n 公里, 旅途中有若干个加油站。 请指出应在哪些加油站停靠加油使得沿途加油次数最少。本题对于给定的正整数 n 和 k 个加油站位置, 请计算最少加油次数。

    汽车加油问题 贪心算法实现 源代码 算法设计与分析实验

    若要使沿途加油次数最少,设计一个有效算法,对于给定的n和k个加油站位置,指出应在哪些加油站停靠加油才能使加油次数最少。 实验提示: 把两加油站的距离放在数组中,a[1..k]表示从起始位置开始跑,经过k个加油站,a...

    JAVA实现汽车加油问题

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

    算法分析汽车加油问题

    设计一个有效算法,指出应在哪些加油站停靠加油,使沿途加油次数最少。 对于给定的n和k(k )个加油站位置,编程计算最少加油次数。 Input 有多个测试用例。每个测试用例输入数据的第一行有2 个正整数n和k,表示...

    汽车加油问题 算法设计

    一辆汽车加满油后可以行驶N千米。旅途中有若干个加油站。指出若要使沿途的加油次数最少,设计一个有效的算法,指出应在那些加油站停靠加油。

    贪心算法解汽车加油问题实验报告

    一辆汽车加满油后可行驶n千米。旅途中有若干个加油站。若要使沿途加油次数最少,设计一个有效算法,指出应在哪些加油站停靠。

    汽车加油问题

    设计一个有效算法,指出应在哪些加油站停靠加油,使沿途加油次数最少。 【设计任务】 对于给定的n和k个加油站位置,计算最少加油次数 输入格式 第一行有2个正整数n和k,表示汽车加满油后可行驶n公里,且旅途中有k个...

    顾客服务排队问题、汽车加油问题(贪心算法).pdf

    包含贪心算法里面的两个典型问题即顾客服务等待问题和汽车加油问题,有具体过程以及代码...若要使沿途加油次数最少,设计一个有效算法,对于给定的n和k个加油站位置,指出应在哪些加油站停靠加油才能使加油次数最少。

    汽车加油问题详细解析及代码

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

    汽车加油问题(贪心算法)

    学习数据结构,算法的人群,问题详情:一辆汽车加满油后可行驶n公里。旅途中有若干个加油站。设计一个有效算法,指出应在哪些加油站停靠加油,使沿途加油次数最少。

    贪心算法实现汽车加油问题

    一辆汽车加满油后可以行驶N千米。旅途中有若干个加油站。若要使沿途的加油次数最少,设计一个有效的算法,指出应在那些加油站停靠加油

    汽车加油问题(贪心算法)c++

    问题描述 一辆汽车加满油后可以行驶nkm。旅途中有若干加油站。设计一个有效算法指出应在哪些加油站停靠加油,使沿途加油次数最少。

    汽车加油问题程序算法

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

    java解决汽车加油问题

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

    汽车加油问题 源代码下载

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

    贪心算法《加油站》.rar

    一辆汽车加满油后可行驶n Km。旅途中有若干个加油站。设计一个有效算法,指出应在哪些加油站停靠加油,是沿途加油次数最少。并证明算法能产生一个最优解

    计算机科学与技术专业算法分析期末课程设计

    给出N,并以数组的形式给出加油站的个数及相邻距离,指出若要使沿途的加油次数最少,设计一个有效的算法,指出应在那些加油站停靠加油。要求:算法执行的速度越快越好。 压缩包内有: 1:源代码,用Dev-C++打开 2:...

    huodonganpai.rar_K._tribefgq_贪心

    汽车加油问题:一辆汽车加满油后可以行驶N千米,汽车从A地开往B地,途中有K个加油站,已知AB两地距离最近一个加油站的距离以及各个加油站和之间的距离(各个加油站之间的距离不完全相等)。设计一个有效的贪心算法使...

Global site tag (gtag.js) - Google Analytics