文档详情

数据结构课程设计迷宫问题求解.doc

发布:2016-12-13约7.74千字共14页下载文档
文本预览下载声明
扬州大学信息工程学院 《数据结构》 ---课程设计报告 题目: 迷宫问题 班级: 计科1301 学号: 131404126 姓名: 张艳 指导教师: 王丽爱 目 录 1 课程题目 2 需求分析 2.1 功能与数据需求 2.1.1 题目要求的功能 2.1.2 扩展功能 2.2 界面需求 2.3 开发环境与运行需求 3 概要设计 3.1主要数据结构 3.2程序总体结构 3.3各模块函数说明 4 详细设计 4.1算法分析与设计 4.2主要程序段设计 5 测试 6 附程序源代码 一、设计题目 迷宫问题 二、需求分析 2.1 功能与数据需求 迷宫求解 问题描述:以一个m×n的长方形表示迷宫,0和1分别表示迷宫中的通路和障碍。设计一个程序,对任意设定的迷宫,求出一条从入口到出口的通路,或得出没有通路的结论。 2.1.1 题目要求的功能 基本要求:首先实现一个以链表作存储结构的栈类型,然后编写一个求解迷宫的非递归程序。求得的通路以三元组(i,j,d)的形式输出,其中:(i,j)指示迷宫中的一个坐标,d表示走到下一坐标的方向。如:对于下列数据的迷宫,输出的一条通路为:(1,1,1), (1,2,2), (2,2,2) (3,2,3), (3,1,2),…。 测试数据:迷宫的测试数据如下:左上角(1,1)为入口,右下角(9,8)为出口。 1 2 3 4 5 6 7 8 2.1.2 扩展功能 (1)编写递归形式的算法,求得迷宫中所有可能的通路; (2)以方阵形式输出迷宫及其通路 2.2 界面需求 请求输入进入程序 请求输入起始位置 请求输入终点位置 输出方阵迷宫 输出路径 输出方阵路径 2.3 开发环境与运行需求 Visual C++6.0 三、概要设计 3.1主要数据结构 3.3各模块函数说明 typedef struct{ int pos_x[length];//进栈坐标 int pos_y[length]; int top; int base; }Stack; //新建结构体 void initStack(Stack *p) //初始化栈 Push(Stack *p,int x,int y,int d) //入栈具体操作 Pop(Stack *p,int read[2],int d) //出栈并读出前一步的坐标 initMaze(int Maze[10][9])//建立迷宫 Ways(Stack *p,int Maze[10][9],int rukou_x,int rukou_y,int chukou_x,int chukou_y,int d) //具体路径的求解 menu();//调用菜单函数 main();//实现迷宫求解的主函数 带头结点的单循环链表抽象数据类型SCLinList,其中包括基本操作的函数有:初始化操作函数、插入一个结点操作函数、删除一个结点操作函数、取一个结点数据操作函数和判表是否非空操作函数。该抽象数据类型文件名为SCLinList.h。 JesephRing()函数是实现问题要求的主要函数。 void SCLLDeleteAfter(SCLNode *p),其功能是删除带头结点的单循环链表中指针p所指结点的下一个结点。 void JesephRing(SCLNode *head, int m),其功能是对带头结点的单循环链表head,以m为初始报数上限值实现问题要求。 void main(void),主函数,功能是给出测试数据值,建立测试数据值的带头结点单循环链表,调用JesephRing()函数实现问题要求。 四、详细设计 迷宫的过程可以模拟
显示全部
相似文档