下载此文档

汽车加油问题之贪心算法.doc


文档分类:汽车/机械/制造 | 页数:约4页 举报非法文档有奖
1/4
下载提示
  • 1.该资料是网友上传的,本站提供全文预览,预览什么样,下载就什么样。
  • 2.下载该文档所得收入归上传者、原创者。
  • 3.下载的文档,不会出现我们的网址水印。
1/4 下载此文档
文档列表 文档介绍
汽车加油问题之贪心算法(一)问题描述   一辆汽车加满油后可以行驶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);   D 加油站间的距离不相等,即a[i]!=a[j],则加油次数k通过以下算法求解。   (三)算法描述    贪心算法的基本思想   该题目求加油最少次数,即求最优解的问题,可分成几个步骤,一般来说,每个步骤的最优解不一定就是整个问题的最优解,然而对于有些问题,局部贪心可以得到全局的最优解。贪心算法将问题的求解过程瞧作就是一系列选择,从问题的某一个初始解出发,向给定目标推进。推进的每一阶段不就是依据某一个固定的递推式,而就是在每一个阶段都瞧上去就是一个最优的决策(在一定的标准下)。不断地将问题实例归纳为更小的相似的子问题,并期望做出的局部最优的选择产生一个全局得最优解。    贪心算法的适用的问题   贪心算法适用的问题必须满足两个属性:   (1)  贪心性质:整体的最优解可通过一系列局部最优解达到,并且每次的选择可以依赖以前做出的选择,但不能依赖于以后的选择。   (2)  最优子结构:问题的整体最优解包含着它的子问题的最优解。    贪心算法的基本步骤   (1)  分解:将原问题分解为若干相互独立的阶段。   (2)  解决:对于每一个阶段求局部的最优解。   (3)  合并:将各个阶段的解合并为原问题的解。    [问题分析]   由于汽车就是由始向终点方向开的,我们最大的麻烦就就是不知道在哪个加油站加油可以使我们既可以到达终点又可以使我们加油次数最少。   提出问题就是解决的开始、为了着手解决遇到的困难,取得最优方案。我们可以假设不到万不得已我们不加油,即除非我们油箱里的油不足以开到下一个加油站,我们才加一次油。在局部找到一个最优的解。却每加一次油我们可以瞧作就是一个新的起点,用相同的递归方法进行下去。最终将各个阶段的最优解合并为原问题的解得到我们原问题的求解。    加油站贪心算法设计(C):   include<math、h>   include<studio、h>   intadd(intb[],intm,intn)   { //求一个从m到n的数列的与   intsb;   for(inti=m;i<n;i++)sb+=b[i];   returnsb;   }   intTanxin(inta[n],intN) //a[n]表示加油站的个数,N为加满油能行驶的最远距离   

汽车加油问题之贪心算法 来自淘豆网www.taodocs.com转载请标明出处.

相关文档 更多>>
非法内容举报中心
文档信息
  • 页数4
  • 收藏数0 收藏
  • 顶次数0
  • 上传人龙的传人
  • 文件大小17 KB
  • 时间2020-07-03