综合性、设计性实验报告
姓名 唐艳 学号 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) 合并:将各个阶段的解合并为原问题的解。
[问题分析]
由于汽车是由始向终点方向开的,我们最大的麻烦就是不知道在哪个加油站加油可以使我们既可以到达终点又可以使我们加油次数最少。
提出问题是解决的开始.为了着手解决遇到的困难,取得最优方案。我们可以假设不到万不得已我们不加油,即除非我们油箱里的油不足以开到下一个加油站,我们才加一次油。在局部找到一个最优的解。却每加一次油我们可以看作是一个新的起点,用相同的递归方法进行下去。最终将各个阶段的最优解合并为原问题的解得到我们原问题的求解。
计算机算法与设计分析实验报告班级姓名学号目录实验一分治与递归11基本递归算法12棋盘覆盖问题23二分搜索34实验小结5实验二动态规…
一实验名称用贪心算法回溯算法动态规划等解决汽车加油次数最少问题二实验目的课程设计是计算机算法与设计课程不可缺少的重要实践性环节通过…
第三次算法作业贪心算法姓名吴迪班级08211312学号08211488班内序号15摘要本文为完成作业problem1problem…
算法分析与设计实验报告完成日期20xx11117实验目的1了解贪心算法思想2掌握贪心法典型问题如背包问题作业调度问题等实验内容1编…
算法设计与分析实验报告班级姓名学号年月日目录实验一二分查找程序实现03页实验二棋盘覆盖问题分治法08页实验三01背包问题的动态规划…
算法设计与分析实验报告贪心算法姓名专业班级学号指导教师完成日期XXXXXX3XXXXXXXXX一试验名称贪心算法1写出源程序并编译…
计算机算法与设计分析实验报告班级计科115班姓名孙龙龙学号08113490指导老师张永平计算机科学与技术学院20xx1230目录实…
一实验名称用贪心算法回溯算法动态规划等解决汽车加油次数最少问题二实验目的课程设计是计算机算法与设计课程不可缺少的重要实践性环节通过…
计算机算法与设计分析实验报告班级姓名学号目录实验一分治与递归11基本递归算法12棋盘覆盖问题23二分搜索34实验小结5实验二动态规…