- 1、本文档共15页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
数据结构课程设计拯救007
数据结构课程设计
最短路径:拯救007
专业 XX 学生姓名 XX 班级 XX 学号 XX
问题描述与分析
课程设计目的
图结构是一种较为复杂的数据结构。对图结构最主要、最基本的操作是图的遍历。典型的遍历方法主要是深度遍历和广度遍历,即深度优先搜索和广度优先搜索。图结构也是一种具有广泛应用的数据结构。图的应用问题主要可归结为:求图中顶点间的最短路径、图的关键路径、图的拓扑排序、图的最小生成树等。本课程设计通过“拯救007”案例回顾图的最短路径的基本知识和基本方法。
课程设计内容
看过007系列的电影的人们一定很熟悉Jams Bond这个世界上最著名的特工了。在电影“Live And Let Die”中Jams Bond被一组毒品贩子抓住并且关到湖中心的一个小岛上,而湖中有很多凶猛的鳄鱼。这时Jams Bond做出了一个最惊心动魄的事情来逃脱——他跳到了最近的鳄鱼的头上,在鳄鱼还没有反映过来的时候,他有跳到另一支鳄鱼的头上······最后他终于安全地跳到了湖岸上。
假设湖是100*100的正方形,设湖的中心在(0,0),湖的东北角的坐标是(50,50)。湖中心的圆环小岛的圆心在(0,0),直径是15.。一些凶残的鳄鱼分布在湖中不同的位置。现已知的湖中的鳄鱼的位置和Jams Bond可以跳的最大距离,请你告诉Jams Bondyitiao 最短的到达湖边的路径。他逃出去的路径长度等于他跳的次数。
程序从“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
45 0
-1 /*对应第二组数据的输出*/
提示:将每个鳄鱼看作图中的每一个顶点。如果007可以从A点跳到B点,则A和B之间就有一条边。
设计分析
明确题目中的已知条件
(1)007被关的小岛在湖的中心;
小岛是圆形,圆心(0,0),而直径是15;
没有两只鳄鱼在同一位置;
鳄鱼的坐标值都是整数。
2.一些判断007是否跳出的细节
(1)判断007是否能够直接从岛上跳到湖岸由已知条件可得湖是一个正方形
变长为100中心是在(0,0),四个顶点分别是
(50,50),(50,-50),(-50,-50),(-50,50)。而湖中小岛的直径是15.所以如果007可
以跳大于(50-15/2)=42.5,他就可以直接从小岛跳到湖岸而不是经过鳄鱼。
(2)判断007是否能够从岛上跳到湖中点A已知小岛的半径是7.5假设点A的
坐标是(x,y),007的步长是L则当点A到中心的(0,0)的距离小于等于007的步长加
上小岛的半径7.5的时候就能确定007可以从岛上跳到点A即
(3)判断007是否能从点A跳到点B假设007的步长是L所以如果两点之间的距
离小于等于L则判断007可以冲A跳到B即 其他情况是007不能从A点跳到B点。
(4)判断007是否能够从点A跳到湖岸当从A点到湖岸的距离小于的ing与007
的步长的时候说明他可以从A点跳到湖岸 或 其他情况时007不能从A点跳到
湖岸。
主要数据结构与算法见附录Ⅰ。
在执行完算法read_case后*Bank值可能有如下3种可能
(1)0意味着007无法逃脱出去
(2)1,意味着007可以直接从岛上跳出去而不用经过鳄鱼的脑袋
(3)k,返回的k点是007经过的最短路径掏出鳄鱼潭时经过的最后一个顶点。可
以根据G[k]的path参数来追踪改点上的一点由此类推可以得到007逃脱的最短路
径。
3.2系统功能模块划分
本程序包含3个头文件和4个C源程序文件分别是Graph.h、Graph.c、
Deque.h、Deque.c、error.h、error.c、main.c。程序内容见附录Ⅱ。
4 测试
4.1 测试方案
您可能关注的文档
最近下载
- 党性党风党纪专题教育课件.ppt VIP
- 数控技术参考文献.pdf VIP
- 2024年第五届“红旗杯”班组长综合技能知识大赛考试题库及答案(通用版).docx VIP
- AEC - Q100-004 - Rev-D - IC Latch-Up Test集成电路闩锁.pdf
- 2024物理中考专题亮点-专题04 物理阅读理解中考考题(含答案与解析) .pdf
- 数学人教版八年级上册数学活动:折纸做60°、30°、15°的角.doc
- 2023年药学考试-中药学(副高)历年考试真题试卷摘选答案.docx
- 外研版八年级英语下册module4单元整体作业设计案例.pdf
- 小升初数学专项试题-周长、面积、体积相关问题应用题闯关-通用版(附答案).docx VIP
- YYT-0664-2020医疗器械软件软件生存周期过程核查表.doc VIP
文档评论(0)