数据结构课程设计拯救007.doc

  1. 1、本文档共15页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 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 测试方案

文档评论(0)

yigang0925 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档