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

综合性、设计性实验报告

姓名     唐艳      学号  200908001124

专业计算机科学与技术班级2009 

实验课程名称      算法设计与分析     

指导教师及职称     吕兰兰 讲师      

开课学期 20## 2012  学年    学期

上课时间     2011 10 18     

湖南科技学院教务处编印


一、实验设计方案


二、实验报告


 

第二篇:学生实验贪心算法解汽车加油问题

一、实验名称

    用贪心算法、回溯算法、动态规划等解决汽车加油次数最少问题。   

二、实验目的: 

       课程设计是《计算机算法与设计》课程不可缺少的重要实践性环节。通过实践教学,要达到以下目的:

(1)使学生掌握线性表、栈、队列、串、树、二叉树、图、集合等各种典型抽象数据类型的数学模型及其所支持基本运算的实现方法;

(2)使学生掌握以抽象数据类型为模块的面向对象程序设计方法;

(3)使学生提高对实际问题的分析、设计和实现能力;

(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.贪心算法解决方案

l  贪心算法的基本思想

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

l  贪心算法的适用的问题

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

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

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

l  贪心算法的基本步骤

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

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

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

[问题分析]

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

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

相关推荐