- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
数据结构最短路径:拯救007
数据结构课程设计报告
( 2011 -- 2012 年度第 1 学期)
最短路径:拯救007
专业 计算机科学与技术(网络工程) 学生姓名 赵宝文 班级 B计算机102 学号 指导教师 田明 完成日期 2012年1月14日
目 录
1 概 述 1
1.1 课程设计目的 1
1.2 课程设计内容 1
2 系统需求分析 2
2.1 系统目标 2
2.2 主体功能 2
2.3 开发环境 2
3 系统需求分析 2
3.1设计分析 2
3.2系统功能模块划分 3
4 测试 3
4.1 测试方案 3
4.2 测试结果 4
5 分析与探讨 5
5.1 测试结果分析 5
5.2 探讨与改进 5
6 小结 5
参考文献 6
附 录 7
附录Ⅰ 7
附录Ⅱ 11
最短路径:拯救007
1 概 述
1.1 课程设计目的
图结构是一种较为复杂的数据结构。对图结构最主要、最基本的操作是图的遍历。典型的遍历方法主要是深度遍历与广度遍历,即深度优先搜索和广度优先搜索。图结构也是一种具有广泛应用的数据结构。图的应用问题主要可归结为:求图中顶点间的最短路径、图的关键路径、图的拓扑排序、图的最小生成树等。本课程设计通过“拯救007”案例回顾图的最短路径的基本知识和基本方法。
1.2 课程设计内容
看过007系列电影的人们一旦很熟悉Janes Bond这个世界上最著名的特工了。在电影“Live and Let Die”中James Bond被异族毒贩子捉住并且关单哦湖中心的一个小岛上,而湖中有很多凶猛的鳄鱼 。这时James Bond做出了最惊心动魄的事情来逃脱——他跳到了最近的鳄鱼头上,在鳄鱼还没有反应过来的时候,他又跳到;额另一只鳄鱼的头上……最后他终于安全的跳到了湖岸上。
假设湖是100*100的正方形,设湖的中心在(0,0),湖的东北角的坐标是(50,50)。湖中心的原型小岛的圆心在(0,0),直径是15。一些凶残的鳄鱼分布在湖中不同的位置。现已知湖中鳄鱼的位置(坐标)和James Bond可以调的最大距离,请你告诉James Bond一条最短的到达湖边的路径。他逃出去的路径长度等于他跳的次数。
输入要求:
程序从“input.txt”,文件中读取输入信息,这个文件包含了多组输入数据。每组输入数 据的起始行中包含两个整数n和d,n是鳄鱼的数量而且n≤100,d是007可以跳的最大距离而且d0。起始行下面的每一行是鳄鱼的坐标(x,y),其中x,y都是整数,而且没有任何两只鳄鱼出现在同一个位置。input.txt文件以一个负数结尾。
输出要求:
程序结果输出到output.txt文件中。对于每组输人数据,如果007可以逃脱,则输出到output.txt文件的内容格式如下:第一行是007必须跳的最小的步数,然后下面按照跳出顺序记录跳出路径上的鳄鱼坐标(x,y),每行一个坐标。如果007不可能跳出去,则将-1写人文件。如果这里有很多个最短的路径,只需输出其中的任意一种。
输入例子:
4 10 /*第一组输人数据*/
17 0
27 0
37 0
45 0
1 10 /*第二组输入数据*/
20 30
-1
输出例子:
5 /*对应第一组数据的输出*/
17 0
27 0
37 0
45 0
-1 /*对应第二组数据的输出*/2 系统需求分析
2.1 系统目标
告诉James Bond一条最短的到达湖边的路径。
2.2 主体功能
假设湖是100*100的正方形,设湖的中心在(0,0),湖的东北角的坐标是(50,50)。湖中心的原型小岛的圆心在(0,0),直径是15。一些凶残的鳄鱼分布在湖中不同的位置。现已知湖中鳄鱼的位置(坐标)和James Bond可以调的最大距离,请你告诉James Bond一条最短的到达湖边的路径。他逃出去的路径长度等于他跳的次数。
2.3 开发环境
VC++6.0
3 系统需求分析
3.1设计分析
1.明确题目中的已知条件
(1)007被关的小岛在湖的中心;
(2)小岛是圆形,圆心(0,0),而且直径是15;
(3)没有两只鳄鱼在同一位置;
(4)鳄鱼的坐标值都是整数。
2.一些判断007是否跳出的细节
(1)判断007是否能够直接从岛上跳到湖岸:由已知条件可得,湖是一个正方形,变长为100,中心是在(0,0),四个顶点分别是(50,50),(50,-50),(-50,-50),(-50,50)。而湖中小岛的直径是15.所以如果007可以跳大于(50-15/2)=42.5,他就可以直接从小岛跳到湖岸,而不是经过鳄鱼。
(2)判
文档评论(0)