《校园导航系统》课程设计报告

合集下载
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

《校园导航系统》课程设计报告

姓名:

学号:

班级:网络

专业:网络工程

指导教师:

时间:2

目录

摘要 (1)

1.题目 (1)

2.概要设计 (1)

3.调试分析 (15)

4.参考文献 (15)

1.题目

校园导航系统

设计一个校园导游程序,后台操作:

1、操作员信息管理如修改密码等

2、能根据学校的规模进行添加景点信息、修改景点信息等功能,

3、若临时有交通管制,能进行交通管制的设置和撤销(如某某时间段那条路进行那个方向的交通管制等)

前台为来访的客人提供各种信息查询服务:

1、设计学校的校园平面图,所含景点不少于10个。以图中顶点表示校内各景点,存放景点名

称、代号、简介等信息;以边表示路径,存放路径长度等相关信息。

2、为来访客人提供图中任意景点相关信息的查询。

3、提供途中任意景点问路查询,即求任意两个景点间的一条最短的简单路径。

1.1 需求分析

设计一个校园导航系统,导航系统又分为游客和管理员。要进行管理操作还是游客操作由用户自己选择

管理员的操作:修改景点信息、增加景点信息、交通管制等。

游客的操作:查看景点信息和查最短路径。

2.概要设计

景点的信息由一维数组存放,景点关系由二维数据来存放

景点的信息和关系从文件读取,进而初始化

typedef struct //保存单个景点信息的结构体

{

char code[10]; //存放景点代码

char name[20]; //存放景点名称

char instruction[100]; //存放景点简介

}ViewPoint;

typedef struct //存放景点关系的二维数组

{

int edges[MAXV][MAXV]; //两景点间的距离

int number; //景点的数量

ViewPoint V[MAXV]; //保存景点信息的结构体数组

}MGraph;

2.1 流程图

2.2详细设计

void MainMenu(); 主菜单,写界面操作的函数。

void UserMenu(); 游客菜单,判断是否非法输入,不会死循环。

void Map(); 输出民大地图,由于时间关系,没有画出。

void ViewAsk(); 游客查询景点函数,让游客选择要查询的景点,判断是否非法输入,不会死循环。void PathAsk(); 问路函数,根据游客的起点和终点给出最短路径,判断是否非法输入,不会死循环。

void Dijkstra(MGraph G,int v,int i); 迪杰斯特拉函数求最短路径

void Ppath(MGraph G,int path[],int i,int v); 输出最短路径中的景点

void Dispath(MGraph G,int dist[],int path[],int s[],int n,int v,int i); 查找最短路径。

void AdminMenu(); 管理员菜单,判断是否非法输入,不会死循环。

void Password(); 密码函数,管理员需输入密码才能进入后台,输入一次后无需再输入。

void AdminAlter(); 修改密码,需要再次输入密码。

void ViewAdd(); 增加景点,列出已有景点,判断新景点信息是和与已有景点的冲突,如冲突需重新输入,判断是否非法输入,不会死循环。

void ViewAlter(); 修改景点信息,由于时间关系,没有判断新修改的景点信息是否与已有景点信息

冲突。若要做次判断,应与增加景点的判断算法一致。

void ControlMenu(); 交通管制菜单,判断是否非法输入,不会死循环。

void PathControl(); 路径管理,可增加路径和修改路径,列出已有路径,根据用户的输入进行管理,

判断是否非法输入,不会死循环。但路径长度为整型,没有判断,若输入非整

型,则进入死循环,一个大大的BUG ,能力有限。

void PathDel(); 删除路径,列出已有路径,用户根据提示进行删除。判断是否非法输入,不会死

循环。

void Read(MGraph &G); 读取文件。

void White(MGraph &G); 保存文件。

2.3

操作界面 程序一开始登录主界面:

游客菜单:

管理员界面

管理员界面

管理员操作界面

查询景点

查询最短路径

修改密码

增加景点

修改景点信息

交通管制界面

删除路径

管理路径

3 调试分析:

当进入操作界面进行功能的选择,但非法输入时,应该提示错误并可以让用户重新选择,我使用的接收选择的是字符串,判断字符串长度是否等于1,如果不等于则是错误的,等于1后用switch 判断第一个字符,与case比较,调用相应的函数。用whlie(1),使之一直循环,直到与case中相同,使用标志和break;让他跳出相应的循环层。在这里经常会出错,所以要很小心的判断每个标志跳出的相应的循环,使他不会跳出不该跳出的循环。

另一个问题是最短路径。在新增一个景点后,我选择不添加相邻的路径时(矩阵的行等于列始终为0,表示同一个景点到同一个景点的路径为0),再次查询最短路径时,起点为新增的路径,终点为任何一个景点都无法运行;但是起点为除新增景点外的景点,而终点为新增景点时,可正确输出:没有路径。由于时间原因来不及调试了。

参考文献

[1]严蔚敏、吴为民.数据结构(C语言版).北京:清华大学出版社.2007

[2]林小茶.C语言程序设计(第二版).中国铁道出版社.2010

[3]杜茂康、李昌兵等.C++面向对象程序设计(第2版).北京:电子工业出版社.2011

相关文档
最新文档