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

上传人:b****3 文档编号:27471496 上传时间:2023-07-01 格式:DOCX 页数:59 大小:491.50KB
下载 相关 举报
《校园导航系统》课程设计报告.docx_第1页
第1页 / 共59页
《校园导航系统》课程设计报告.docx_第2页
第2页 / 共59页
《校园导航系统》课程设计报告.docx_第3页
第3页 / 共59页
《校园导航系统》课程设计报告.docx_第4页
第4页 / 共59页
《校园导航系统》课程设计报告.docx_第5页
第5页 / 共59页
点击查看更多>>
下载资源
资源描述

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

《《校园导航系统》课程设计报告.docx》由会员分享,可在线阅读,更多相关《《校园导航系统》课程设计报告.docx(59页珍藏版)》请在冰豆网上搜索。

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

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

 

《校园导航系统》

课程设计报告

 

姓名:

学号:

班级:

网络

专业:

网络工程

指导教师:

时间:

2

 

摘要……………………………………………………………….……………….1

1.题目…………………………………………………………….……………….1

2.概要设计……………………………………………………………………….1

3.调试分析……………………………………………………………………….15

4.参考文献……………………………………………………………………….15

 

1.

题目

校园导航系统

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

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

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

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

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

1、设计学校的校园平面图,所含景点不少于10个。

以图中顶点表示校内各景点,存放景点名称、代号、简介等信息;以边表示路径,存放路径长度等相关信息。

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

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

 

1.1需求分析

设计一个校园导航系统,导航系统又分为游客和管理员。

要进行管理操作还是游客操作由用户自己选择

管理员的操作:

修改景点信息、增加景点信息、交通管制等。

游客的操作:

查看景点信息和查最短路径。

2.概要设计

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

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

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

{

charcode[10];//存放景点代码

charname[20];//存放景点名称

charinstruction[100];//存放景点简介

}ViewPoint;

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

{

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

intnumber;//景点的数量

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

}MGraph;

2.1流程图

函数开始

接收功能的请求

接受信息输入

判断是否正确

读取文件

进行相对应操作

写回文件

函数结束

2.2详细设计

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

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

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

voidViewAsk();游客查询景点函数,让游客选择要查询的景点,判断是否非法输入,不会死循环。

voidPathAsk();问路函数,根据游客的起点和终点给出最短路径,判断是否非法输入,不会死循环。

voidDijkstra(MGraphG,intv,inti);迪杰斯特拉函数求最短路径

voidPpath(MGraphG,intpath[],inti,intv);输出最短路径中的景点

voidDispath(MGraphG,intdist[],intpath[],ints[],intn,intv,inti);查找最短路径。

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

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

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

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

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

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

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

voidPathControl();路径管理,可增加路径和修改路径,列出已有路径,根据用户的输入进行管理,判断是否非法输入,不会死循环。

但路径长度为整型,没有判断,若输入非整型,则进入死循环,一个大大的BUG,能力有限。

voidPathDel();删除路径,列出已有路径,用户根据提示进行删除。

判断是否非法输入,不会死循环。

voidRead(MGraph&G);读取文件。

voidWhite(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

 

附录

源程序

:

头文件详细代码

#include

#include

#include

#include

#include

#include

#include

#defineMAXV100

#defineINF10000

typedefstruct

{

charcode[10];

charname[20];

charinstruction[100];

}ViewPoint;

typedefstruct

{

intedges[MAXV][MAXV];

intnumber;

ViewPointV[MAXV];

}MGraph;

voidMainMenu();

voidUserMenu();

voidMap();

voidViewAsk();

voidPathAsk();

voidDijkstra(MGraphG,intv,inti);

voidPpath(MGraphG,intpath[],inti,intv);

voidDispath(MGraphG,intdist[],intpath[],ints[],intn,intv,inti);

voidAdminMenu();

voidPassword();

voidAdminAlter();

voidViewAdd();

voidViewAlter();

voidControlMenu();

voidPathControl();

voidPathDel();

voidRead(MGraph&G);

voidWhite(MGraph&G);

:

主函数

#include"All.h"

main()

{

intpass;

charname[10],password[10];

ifstreamindata("Password.txt");

indata>>pass>>name>>password;

indata.close();

pass=0;

ofstreamoutdata("Password.txt");

outdata<

outdata.close();

MainMenu();

}

:

菜单功能

#include"All.h"

voidMainMenu()

{

system("cls");

charchoose[1];

cout<<"\n\n\n"<

"<

cout<

"<

cout<

cout<

cout<

cout<

cout<

cout<

cout<

";

cin>>choose;

if(strlen(choose)==1)

{

switch(choose[0])

{

case'1':

UserMenu();break;

case'2':

Password();break;

case'3':

exit(0);

default:

system("cls");

cout<<"\n\n\n"<

"<

cout<

";

cout<

getch();

MainMenu();

break;

}

}

else

{

system("cls");

cout<<"\n\n\n"<

"<

cout<

";

cout<

getch();

MainMenu();

}

}

voidUserMenu()

{

system("cls");

charchoose[1];

intflag=0;

cout<<"\n\n\n"<

"<

cout<

cout<

cout<

cout<

cout<

cout<

cout<

cout<

cout<

cout<

cout<

";

cin>>choose;

if(strlen(choose)==1)

{

switch(choose[0])

{

case'1':

Map();break;

case'2':

ViewAsk();break;

case'3':

PathAsk();break;

case'4':

MainMenu();break;

case'5':

exit(0);

default:

system("cls");

cout<<"\n\n\n"<

"<

cout<

";

cout<

getch();

UserMenu();

}

}

else

{

system("cls");

cout<<"\n\n\n"<

"<

cout<

";

cout<

getch();

UserMenu();

}

}

voidPassword()

{

system("cls");

charname[10],password[10];

charentername[10],enterpassword[10];

charchoose[1];

intpass,flag=0,flag1=0;

ifstreamindata("Password.txt");

indata>>pass>>name>>password;

indata.close();

if(pass)

AdminMenu();

else

{

cout<<"\n\n\n"<

";

cin>>entername;

cout<

";

cin>>enterpassword;

if(strcmp(name,entername)==0&&strcmp(password,enterpassword)==0)

{

pass=1;

ofstreamoutdata("Password.txt");

outdata<

outdata.close();

AdminMenu();

}

else

{

system("cls");

cout<<"\n\n\n";

cout<

"<

while

(1)

{

if(flag1)

{

system("cls");

cout<<"\n\n\n";

}

cout<

cout<

cout<

cout<

cout<

cout<

cout<

";

cin>>choose;

if(strlen(choose)==1)

{

switch(choose[0])

{

case'1':

flag=1;Password();break;

case'2':

flag=1;MainMenu();break;

case'3':

exit(0);

default:

flag1=1;

system("cls");

cout<<"\n\n\n"<

"<

cout<

";

cout<

getch();

}

if(flag)

break;

}

else

{

flag1=1;

system("cls");

cout<<"\n\n\n"<

"<

cout<

";

cout<

getch();

}

}

}

}

}

voidAdminMenu()

{

system("cls");

charchoose[1];

intflag=0;

cout<<"\n\n\n"<

"<

cout<

cout<

cout<

cout<

cout<

cout<

cout<

cout<

cout<

cout<

cout<

cout<

cout<

";

cin>>choose;

if(strlen(choose)==1)

{

switch(choose[0])

{

case'1':

AdminAlter();break;

case'2':

ViewAdd();break;

case'3':

ViewAlter();break;

case'4':

ControlMenu();break;

case'5':

MainMenu();break;

case'6':

exit(0);

default:

system("cls");

cout<<"\n\n\n"<

"<

cout<

";

cout<

getch();

AdminMenu();

}

}

else

{

system("cls");

cout<<"\n\n\n"<

"<

cout<

";

cout<

getch();

AdminMenu();

}

}

voidControlMenu()

{

system("cls");

charchoose[1];

cout<<"\n\n\n"<

"<

cout<

cout<

cout<

cout<

cout<

cout<

cout<

cout<

cout<

";

cin>>choose;

if(strlen(choose)==1)

{

switch(choose[0])

{

case'1':

PathControl();break;

case'2':

PathDel();break;

case'3':

AdminMenu();break;

case'4':

exit(0);

default:

system("cls");

cout<<"\n\n\n"<

"<

cout<

";

cout<

getch();

ControlMenu();

}

}

else

{

system("cls");

cout<<"\n\n\n"<

"<

cout<

";

cout<

getch();

ControlMenu();

}

}

:

包涵游客用的函数

#include"All.h"

voidMap()

{

system("cls");

cout<<"\n\n\n"<

"<

cout<

cout<

getch();

UserMenu();

}

voidViewAsk()

{

system("cls");

MGraphG;

charviewpoint[20];

charchoose[1];

inti,flag=0,flag1=1,flag2=0;

Read(G);

cout<

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 医药卫生 > 中医中药

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1