校园导游咨询程序设计报告
校园导游咨询系统课程设计报告
目录一、需求分析 (2)二、概要设计 (2)三、详细设计 (4)四、设计和调试分析 (9)五、用户手册 (9)六、测试结果 (10)1.操作命令符为s/S, (10)2.操作命令符为v/V, (11)3.操作符为v/V, (11)4.操作符为e/E, (11)5.综上可以查得: (12)七、附录 (12)参考文献 (13)校园导游咨询系统一、需求分析1.从福建农林大学的平面图中选取28个有代表性的景点,抽象成一个无向带权图。
以图中顶点表示景点,边上的权值表示两地间的距离。
2.本程序的目的是为了用户提供路径咨询,根据用户指定的始点和终点输出相应路径,或者根据用户指定的景点输出景点的信息。
3.测试数据(附后)。
二、概要设计1.抽象数据类型图的定义如下:ADT {struct arcnode{ int v;int w;struct arcnode *next;};struct node{ int degree;struct arcnode *first;}adjlist[28];}2.主程序V oid mian(){初始化临接矩阵windows(); / /初始化串口getch();}3.函数定义的变量#define infi 32767#define MAX 28int M,N; //无向图中的顶点M,无向图的变数int adjmatrix[MAX][MAX]; // 保存临接矩阵的2唯数组char *schoolIfo[MAX+1]={ //此数组用于界面显示信息"null","东台-dt","金1-j1","金2-j2","金3-j3","金4-j4","食堂-st","田径场-tjc","校大门-xdm","创业园-cyy","校医院-xyy","图书馆-tsg","映辉桥-yhq","观音湖-gyh","成教楼-cjl","生物楼-swl","博学楼-bxl","创新楼-cxl","明德楼-mdl","拓荒广场-thgc","南区公寓-nqgy","田家炳楼-tjbl","农大新区-ndxq","中华广场-zhgc","905终点站-zdz","蜂疗医院-flyy","研究生公寓-yjsgy","昌融学生街-crxsj","北区学生公寓-bqxsgy"};char *charcd2[MAX]={ //用于显示最短路径时走向的数组"校大门","金1","昌融学生街","创业园","东台","金2","田径场","拓荒广场","南区公寓","校医院","食堂","成教楼","创新楼","田家炳楼","农大新区","观音湖","金3","映辉桥","金4","明德楼","中华广场","905终点站","蜂疗医院","生物楼","博学楼","图书馆","研究生公寓","北区学生公寓"};char *charcd[MAX]={ //用于用户输入起始点与终止点时对应的数组"xdm","j1","crxsj","cyy","dt","j2","tjc","thgc","nqgy","xyy","st","cjl","cxl","tjbl","ndxq","gyh","j3","yhq","j4","mdl","zhgc","zdz","flyy","swl","bxl","tsg","yjsgy","bqxsgy"};char *infor[MAX]={ //介绍景点信息数组"校大门:\n 占不提供介绍","金1:\n 指金山大道的一处,由图可知","昌融学士街:\n 农大的小吃一条街,来农大一定要来尝尝!","创业园:\n 农大创业有志者的孵化地","东台:\n 农大老师所住之处","金2:\n 金山大道的第二处有图可看出","田径场:\n 农大的运动场地","拓荒广场:\n 大礼堂就在此处","南区公寓:\n 顾名思意,学生公寓","校医院:\n 希望你不要来","食堂:\n 学校八九十食堂都在这,不错蛮好吃的。
齐鲁工业大学校园导游咨询系统设计报告
成绩:__________________ 校园导游系统设计报告学院名称理学院一、系统分析此次课程设计的主要内容是校园导航系统,所谓系统其实也不尽然,只不过是个小小的提示,为来访的客人提供各种信息查询服务。
主要包括:①查看学校的全景图②各个景点的简介③学校主要景点的分布④查看某一景点到其它所有景点的最短路径⑤查询任意两个景点之间的最短路径。
矚慫润厲钐瘗睞枥庑赖。
二、概要设计抽象数据类型的定义:ADT Graph{数据对象 V:V具有相同特性的数组元素的集合,称为顶点集。
数据关系 R:R={VR}VR={<v,w>|v,w∈V且P(v,w),<v,w> 表示从v到w的弧,谓词P(v,w)定义了弧<v,w>的意义或信息}聞創沟燴鐺險爱氇谴净。
基本操作P:CreateGraph(&G,V,VR);初始条件:V是图的顶点集,VR是图中弧的集合。
操作结果:按V和VR的定义构造图G。
DistroyGraph(&G)初始条件:图G存在操作结果:销毁图GLocateVex(G,u);初始条件:图G存在,u和G中顶点有相同的特征。
操作结果:若存在顶点u,则返回该顶点在图中的位置;否则返回其他信息。
GetVex(G,u);初始条件:图G存在,u是图中的顶点。
操作结果:返回u的值。
InsertVex(&G,v);初始条件:图G存在,v和图中的顶点有相同的特性。
操作结果:在图G中新增顶点v.InsertArc(&G,v,w);初始条件:图G存在,v和w是图中的顶点。
操作结果:在图G中增添弧<v,w>,若是无向图,还增添弧<w,v>。
}ADT Graph主程序流程(各函数之间的调用关系):Main();//主函数Initview();//景点信息的初始化InitLength();//各个景点之间距离的初始化log();//登录时的头部showmenu();//登录后的菜单browser();//全景图的浏览browse_view_info();//景点简介的查询browse_view_distribute();//主要景点的分布onetoall();//某一景点到其它所有景点的最短路径onetoone();//查询任意两个景点之间的最短路径三、详细设计#include<stdio.h>#include<string.h>#include<windows.h>#include<conio.h>#include<malloc.h>#define MAX 50#define TRUE 1#define FALSE 0#define INFINITY 10000typedef int **PathMatrix;typedef int *DistancMatrix;typedef struct view{ int no;//景点编号char name[100];//景点名称char briefinfo[1000];//景点简介}view;typedef struct edge{ //pathlength arcs;//两个景点之间的距离int length; char direction[4];//方向}edge;void showmenu(){printf(" 齐鲁工业大学主要景点列表 \n");printf("\t*********************************************************\n"); 残骛楼諍锩瀨濟溆塹籟。
校园导游咨询程序设计报告
数据结构课程设计设计题目:校园导游咨询学院:信息学院班级:计算机1008班姓名:学号: 20101221180日期: 2012 年 3 月校园导航问题[问题描述]设计一个校园导游程序,为来访的客人提供各种信息查询服务。
[基本要求](1)设计所在学校的校园平面图,所含景点不少于十个。
以图中顶点表示校内各景点,存放景点名称、代号、简介等信息;以边表示路径,存放路径长度等信息。
(2)为来访客人提供图中任意景点相关信息的查询。
(3)为来访客人提供图中任意景点的问路查询,即查询任意两个顶点之间的一条最短的简单路径。
(4)校园导游图的景点和道路的修改扩充功能。
(5)扩充道路信息,如道路类别(车道、人行道),以致可按客人所需分别查询人行路径或车行路径。
(6)扩充每个景点的林洁景点的方向等信息,使得路径查询结果能提供详尽的导向信息。
(7)实现校园导游的仿真界面。
一、概要设计 (4)二、详细设计 (6)三、调试分析 (12)四、调用关系 (12)五、用户操作指南 (13)[测试数据]一、概要设计1. 数据类型#define V_MAX 20#define E_MAX 200typedef struct {char name[10];//名字//char code[10];//代码char info[20];//信息,简介int x,y;//坐标}VType;//顶点类型typedef struct {int live;//标记是否存在,如果被删除则为0,存在为1 char name[10];// 路名int length;//路的长度char ivex[10],jvex[10];//路(边)连接的两个顶点的名字int type;//表示道路类型,0表示两个都是,1表示人行道,2表示行车道}EdgeType;//边类型typedef struct AdjNode{int length;// 弧的长度char name[10];//关联的顶点的名字struct AdjNode *next;//下一条弧}AdjNode;//弧结点typedef struct {int live;//标记是否存在,如果被删除则为0,存在为1int flag;//标记是否被访问过VType data;//顶点的信息AdjNode *first_adj;//指向该顶点的第一条弧}VNode;//景点(顶点)结点typedef struct {VNode vex[V_MAX];//顶点数组EdgeType edge[E_MAX];//边的数组int v_num,e_num;}Graph;//图类型////////////////////////////////Graph G;AdjNode *p;2.基本函数////////////////////////////////void creatGraph(Graph &G);//创建校园图void load(Graph &G);//从文件中读取数据void save(Graph &G);//保存数据入文件int find_v(Graph G,char name[10]);//通过输入景点名字,返回该景点在vex数组里的下标void print_Graph(Graph G);//以邻接矩阵的形式输出图信息int direction(Graph G,char bname[10],char fname[10]);//用于判断并输出一个景点在另外一个景点的方位信息void search_view(Graph G);//查询并输出景点的所有信息void del_v(Graph &G);//删除景点void add_v(Graph &G);//增加景点void add_e(Graph &G)//增加道路void modify_v(Graph &G);//修改景点信息void del_e(Graph &G);//删除道路二、详细设计本程序由m.cpp、head.h、Menu.h、dijie.h4个文件构成。
校园导游咨询实验报告
本实验旨在通过设计并实现一个校园导游咨询系统,提高学生对数据结构在实际问题中的应用能力,培养编程实践能力和问题解决能力。
通过本次实验,学生能够深入了解图论在计算机科学中的应用,学会使用图论算法解决实际问题,并掌握Java编程语言在图形用户界面(GUI)设计中的应用。
二、实验内容1. 问题描述设计一个校园导游咨询系统,为来访客人提供以下服务:- 查询校园内景点的详细信息,包括名称、代号、简介等。
- 查询任意两个景点之间的最短路径。
- 提供从指定景点出发,游览所有景点的推荐路径。
2. 基本要求- 设计校园平面图,包含不少于10个景点。
- 以图中顶点表示校内各景点,存储景点名称、代号、简介等信息。
- 以边表示路径,存储路径长度等相关信息。
- 实现景点信息查询、景点间最短路径查询和推荐游览路径查询功能。
3. 数据结构- 采用邻接矩阵存储校园平面图,表示景点间的路径关系。
- 使用前趋结点数组辅助Floyd算法实现最短路径查询。
4. 算法- 使用Floyd算法计算任意两个景点之间的最短路径。
- 使用DFS算法结合贪心思想计算推荐游览路径。
5. 界面设计- 使用Java Swing实现图形用户界面,方便用户进行操作。
1. 需求分析- 与用户沟通,了解用户对校园导游咨询系统的需求。
- 确定系统功能,包括景点信息查询、景点间最短路径查询和推荐游览路径查询。
2. 系统设计- 设计系统架构,包括数据结构、算法和界面设计。
- 确定数据存储方式和算法实现方法。
3. 编码实现- 使用Java编程语言实现系统功能。
- 实现数据结构、算法和界面设计。
4. 测试与调试- 编写测试用例,验证系统功能。
- 调试系统,修复发现的问题。
四、实验结果1. 景点信息查询- 用户可以输入景点代号,查询景点详细信息,包括名称、代号、简介等。
2. 景点间最短路径查询- 用户可以输入两个景点的代号,查询它们之间的最短路径。
3. 推荐游览路径查询- 用户可以输入起始景点的代号,查询从该景点出发,游览所有景点的推荐路径。
校园导游系统实验报告
竭诚为您提供优质文档/双击可除校园导游系统实验报告篇一:校园导游图系统数据结构实验报告一.设计目的通过布置具有一定难度的实际程序设计项目,使学生进一步理解和掌握课堂上所学各种基本抽象数据类型的逻辑结构、存储结构和操作实现算法,以及它们在程序中的使用方法;使学生掌握分析问题,求解问题的方法并提高学生设计编程实现的能力。
二.设计内容用无向网表示学校的校园景点平面图,图中顶点表示主要景点,存放景点的编号、名称、简介等信息,图中的边表示景点间的道路,存放路径长度等信息。
要求能够回答有关景点介绍、游览路径等问题。
游客通过终端可询问:(1)从某一景点到另一景点的最短路径。
(2)游客从公园进入,选取一条最佳路线。
(3)使游客可以不重复地浏览各景点,最后回到出口(出口就在入口旁边)。
[基本要求](1)将导游图看作一张带权无向图,顶点表示公园的各个景点,边表示各景点之间的道路,边上的权值表示距离.为此图选择适当的数据结构。
(2)把各种路径都显示给游客,由游客自己选择浏览路线。
(3)画出景点分布图于屏幕上。
[实现提示] (1)构造一个无向图g并用邻接矩阵来存储。
(2)利用迪杰斯特拉算法来计算出起点到各个顶点之间的最短路径用二维数组p[i][]来记录,最短路径长度就用一维数组d[i]存放;i的范围:0~20。
(3)一维数组have[]是用来记录最短路径出现顶点的顺序。
(4)根据起点和终点输出最短路径和路径长度。
三.概要设计1.功能模块图;2.各个模块详细的功能描述。
1.浏览校园全景:采用深度遍历遍历图进行所有景点浏览,将遍历景点信息输出2.查看所有游览路线:用户输入一个景点,采用迪杰斯特拉算法将从该景点起所有路径查出并输出在屏幕上3.选择出发点和目的地:用户输入一个出发点和一个目的地编号,采用弗洛伊德算法求出发点到目的地的最短路径4.查看景点信息:直接用编号进行单个景点查询。
四.详细设计重点设计及编码在求最短路径时采用迪杰斯特拉算法//迪杰斯特拉算法来计算出起点到各个顶点之间的最短路径,v0为起点voidshortestpath_DIJ(mgraph*g) {//迪杰斯特拉算法,求从顶点v0到其余顶点的最短路经及其带权长度d[v]//若p[v][w]为1,则w是从v0到v的最短路经上的顶点//final[v]类型用于设置访问标志intv,w,i,min,final[20],D[20],p[20][20],t=0,x,flag=1 ,v0;//vo为起始景点的编号while(flag){printf("请输入一个起始景点编号:");scanf("%d",if(v0g->vexnum){printf("景点编号不存在!请重新输入景点编号:");scanf("%d",}if(v0>=0}for(v=0;vvexnum;v++){fin al[v]=0;//初始化各顶点访问标志D[v]=g->arcs[v0][v].adj;//v0到各顶点v的权值赋值给d[v]for(w=0;wvexnum;w++)//初始化p[][]数组,各顶点间的路径全部设置为空路径0p[v][w]=0;if(D[v]final[v0]=1;//v0的访问标志设为1,v属于s集for(i=1;ivexnum;i++)//对其余g.vexnum-1个顶点w,依次求v到w的最短路径{min=InFInITY;for(w=0;wvexnum;w++)//在未被访问的顶点中,查找与v0最近的顶点vif(!final[w])if(D[w]vexnum;w++)//修改v0到其余各顶点w的最短路径权值d[w]if(!final[w]//修改v0到w的权值d[w]for(x=0;xvexnum;x++)//所有v0到v的最短路径上的顶点x,都是v0到w的最短路径上的顶点p[w][x]=p[v][x];p[w][w]=1;}}for(v=0;vvexnum;v++)//输出v0到其它顶点v的最短路径{if(v0!=v)printf("%s",g->vexs[v0].name);//输出景点v0的景点名for(w=0;wvexnum;w++)//对图中每个顶点w,试探w是否是v0到v的最短路径上的顶点{if(p[v][w]t++;}if(t>g->vexnum-1}}五.测试数据及运行结果1.正常测试数据和运行结果1.浏览校园全部景点信息:2.查看景点信息:3.输出两个景点间的最短路径:2.异常测试数据及运行结果1.当输出错误编号时程序没有反映,继续输入直到输入正确:2.当查询两景点编号相同时的最短路径时,结果如下:篇二:校园导游实验报告[1]校园导游实验报告学号:20XX30457018姓名:熊博班级:09计科1班完成日期:20XX-12-211、问题描述制作陶瓷学院的校园导游图,游客通过终端可询问:(1)从某一景点到另一景点的最短路径。
数据结构校园导游咨询系统课程设计报告及课程总结.doc
姓名:班级:学号:指导教师:2012年12月目录1、需求分析 (1)1.1 系统简介 (1)1.2 系统功能模块介绍 (1)2、概要设计 (1)2.1 系统功能结构图 (1)2.2 系统流程图 (2)2.3 主要函数概要设计 (3)2.3.1 主函数概要设计 (3)2.3.2 初始化图函数InitGraph() (3)2.3.4 查询景点信息函数设计SearchGraph() (4)2.3.5 显示图中信息函数设计ShowGraph() (4)2.3.6 弗洛伊德算法函数设计Floyd() (4)3、详细设计 (4)3.1 主函数详细设计 (4)3.2初始化图函数详细设计InitGraph() (5)3.3查询景点信息函数详细设计SearchGraph() (6)3.4 弗洛伊德算法函数详细设计Floyd() (7)4、调试分析 (8)4.1 显示主界面函数测试 (8)4.2 查找两景点间最短路径测试 (9)4.3 查看景点信息测试 (10)5.课程设计总结 (11)6、附录 (12)1、需求分析1.1 系统简介随着现代社会生活节奏的加快,人们外出旅行以寻求放松的时间越来越多。
考虑到游客不可能对所有景点都有所了解,因此可能无法找到游玩景点最省时,最高效的路径,而人工导游成本又过高,故使用C语言,基于《数据结构》中图的相关算法开发了“江西农业大学校园咨询系统”。
开发本系统目的在于为来访我校的游客提供一条最短游览路径,本系统从实际出发,通过对校园平面图的分析,将其转化为数据并保存在系统中,因此系统提供的路径具有较大的可信性。
本系统界面友好,提示信息充分,在实际使用过程中运行良好。
1.2 系统功能模块介绍本系统主要分为以下三大功能模块:1、查询两景点最短路径:用户在选择此功能模块后,按照屏幕上方提示的景点名称及其对应的编号,要求用户输入起点和终点的编号,系统将在已存储的景点中进行匹配,若未找到所需查询的景点编号,系统将提示错误并要求用户再次输入。
校园导游系统程序课程设计报告
一、需求分析设计一个校园导游系统程序,为来访的客人提供各类效劳的信息查询。
(1).设计工商学院校园无向图,所含的景点很多于10个。
以图中极点表示校内各景点,寄存景点名称、代号、简介等信息;以边表示途径,寄存途径长度等相关信息。
(2).为来访客人提供图中任意景点相关信息的查询。
(3).为来访客人提供图中任意景点的问路查询,即查询任意两个景点之间的一条最短的简单途径。
二、设计思路校园旅行模型是由景点和景点之间的途径组成的,因此这完全能够用数据结构中的图来模拟。
用图的结点代表景点,用图的边代表景点之间的途径。
因此第一应设计一个图类。
结点值代表景点信息,边的权值代表景点间的距离。
结点值及边的权值用顺序表存储,因此需要设计一个顺序表类。
本系统需要查询景点信息和求一个景点到另一个景点的最短途径长度及线路,为方便操作,因此给每一个景点一个代码,用结构体类型实现。
计算途径长度和最短线路时可用弗洛伊德(Floyd)算法实现。
最后用switch选择语句选择执行阅读景点信息或查询最短途径。
3 算法设计概要设计3.1.1 程序中包括的模块(1)主程序模块主函数:void main(void)void cmd(void) cmd修改显示框大小,字体背景颜色,初始化景点,景点信息打印菜单,MGraph InitGraph(void); 3.1.2dj=INFINITY;[0][1].adj=80;/*途径度*/[0][2].adj=180;[0][6].adj=200;[1][11].adj=120;[1][2].adj=100;[2][5].adj=50;[3][4].adj=60;[4][9].adj=140;[5][9].adj=250;[5][7].adj=150;[6][7].adj=190;[6][9].adj=150;[8][7].adj=130;[8][6].adj=50;[10][12].adj=100;[9][10].adj=150;[3][4].adj=190;[5][13].adj=150;[14][7].adj=350;[2][3].adj=190;[2][9].adj=150;[2][11].adj=120;[0][8].adj=120;[1][2].adj=50;[10][12].adj=170;[12][15].adj=160;for(i=0;i<;i++)for(j=0;j<;j++)[j][i].adj=[i][j].adj;return G;界面菜单设计:菜单项选择择void Menu(){printf("\n 武汉工商学院院导游图\n");printf(" ┏━━━━━━━━━━━━━━━━━━━━┓\n"); printf(" ┃ 1.阅读校园全景┃\n"); printf(" ┃ 2.查看所有游览线路┃\n"); printf(" ┃ 3.确信两景点之间最短距离┃\n"); printf(" ┃ 4.查看景点信息┃\n"); printf(" ┃ 5.退出导游系统┃\n"); printf(" ┗━━━━━━━━━━━━━━━━━━━━┛\n"); printf("Option-:");}Menu();scanf("%d",&i);while(i!=5){switch(i){case 1:system("cls");Browser(&b);Menu();break;case 2:system("cls");ShortestPath_DIJ(&b);Menu();break;case 3:system("cls");Floyd(&b);Menu();break;case 4:system("cls");Search(&b);Menu();break;case 5:exit(1);break;default:break;}介绍景点:void Browser(MGraph *G){int v;printf("┏━━┳━━━━━━━━━━┳━━━━━━━━━┓\n"); printf("┃编号┃景点名称┃简介┃\n"); printf("┗━━┻━━━━━━━━━━┻━━━━━━━━━┛\n"); for(v=0;v<G->vexnum;v++)printf("┃%-4d┃%-20s┃%-60s\n",G->vexs[v].num,G->vexs[v].name,G->vexs[v].introduction);printf("┗━━┻━━━━━━━━━━┻━━━━━━━━━┛\n"); }要查找的两个景点的最短距离:用floyd算法求两个景点的最短途径void Floyd(MGraph *G)dj;for(u=0;u<G->vexnum;u++)p[v][w][u]=0;if(D[v][w]<INFINITY){ p[v][w][v]=1;p[v][w][w]=1; }}for(u=0;u<G->vexnum;u++)for(v=0;v<G->vexnum;v++)for(w=0;w<G->vexnum;w++)if(D[v][u]+D[u][w]<D[v][w]){ D[v][w]=D[v][u]+D[u][w];for(i=0;i<G->vexnum;i++)p[v][w][i]=p[v][u][i]||p[u][w][i]; }while(flag){ printf("请输入动身地编号:");scanf("%d",&k);if(k<0||k>G->vexnum){ printf("景点编号存!\n请输入动身地编号:");scanf("%d",&k); }printf("请输入目的地编号:");scanf("%d",&j);if(j<0||j>G->vexnum){ printf("景点编号存!\n请输入目的地编号:");scanf("%d",&j); }if(k>=0&&k<G->vexnum&&j>=0&&j<G->vexnum)flag=0; }printf("%s",G->vexs[k].name);for(u=0;u<G->vexnum;u++)if(p[k][j][u]&&k!=u&&j!=u)printf("-->%s",G->vexs[u].name);printf("-->%s",G->vexs[j].name);printf(" 总线路%dm\n",D[k][j]); }查看所有游览线路算法计算,引进一个辅助向量D,它的每一个分量D表示当前所找到的从始点v0到每一个终点vi的的长度。
《校园导游咨询》实验设计报告
设计题目:___校园导游咨询__一、需求分析及规格说明1、要求:用无向网表示学校的校园景点平面图,所含景点不少于十个。
图中顶点表示主要景点,存放景点的代码和名称等信息,图中的边表示景点间的道路,存放路径长度等信息。
设计一个校园导游程序,为来访的客人提供各种信息查询服务。
a)简易菜单管理,界面友好。
b)对城市信息(城市名、城市间的里程)进行录入和编辑(可选);c)为来访客人提供图中任意景点的问路查询,即查询任意两个景点之间的一条最短的简单路径,给出相应的距离。
d)对于任意两个景点之间的一条最短的简单路径,给出所经过景点的信息和距离。
对景点采用相应的字符选择。
2、功能:修改及查询校园各景点的信息3、测试数据:a)请输入出发景点:A 鲁迅像请输入到达景点:F 图书馆b)请输入出发景点:B 音乐楼请输入到达景点:H 体育馆二、概要设计1、数据存储结构:一个结构体数组存放各景点名及其编号;一个二维数组存放两景点间的距离;一个栈结构,存储最短路径所经过的各个点;以及多个辅助数组;2、算法思想:1)使用菜单页,选择不同的功能(修改距离、求最短路径、退出等),进行相应的操作;2)采用邻接矩阵作为数据的存储结构,打表,确定位置,修改距离值;3)利用Dijkstra算法,求两地间的距离,并输出其路径;4)主程序有简易菜单,选择功能模块执行,在程序运行过程中可以反复操作。
3、子函数:void init() //初始化各景点的名称、编号及两地已知距离等信息void list(int pos) //以表格的形式打印邻接矩阵string chto_string(char a) //将景点的编号转换为名称,返回void alter(int x,int y,int dist) //修改相应位置上的距离信息void Dijkstra(int s,int t) //求两点间的最短距离void output(int s,int t) //输出最短距离的路径bool menu(int step) //根据不同的操作序号,实现各自的功能4、主函数:int main(){//初始化景点的各个信息;//显示菜单页,提供修改信息、查最短路径的功能//根据键入的信息,进行相应的操作}三、详细设计1、数据类型:全局变量:int mat[10][10](两点距离) ,p[10](路径前去节点) ,dst[10](到起点的距离);const int MAX=INT_MAX/2(最大值); bool visited[10](结点是否访问过);stack<int> path(存放最短距离的路径);struct liocation // 存放景点的名称及编号信息{ char syb;string name;}school[10];2、基本操作:void init() //初始化各景点的名称、编号及两地已知距离等信息school[],mat[][];void list(int pos) //根据不同的pos,打印对应的表头,及其距离信息,表格的形式;若不连通则不输出string chto_string(char a) //根据给出的编号,搜索其对应的景点名称void alter(int x,int y,int dist) //修改相应位置上的距离信息,mat[x][y]=distvoid Dijkstra(int s,int t) //求两点间的最短距离{//初始化各个景点到起点的距离dst[]=mat[][],到起点的起始距离;//置起点的visited[]为true,即访问过;//循环进行9次以下操作:调整当前点与起点的距离,并记录其前驱点p[];}void output(int s,int t) //输出路径{//将记录下的路径p[],按顺序导入在栈中;(将其逆序)//逐个弹出栈中的元素,输出对应的路径信息,包括起点、中间点、距离;//输出全程最短行程的距离}bool menu(int step) // 菜单内容{//如果输入的操作序号有误,则提示,返回主菜单;//清屏;if(1修改功能){//打印表格,及对应的提示语句;//读取两个景点序号及两地的新距离;//覆盖原来的距离;//不再修改,则返回主菜单;//return true;}else if(求最短路径功能){//打印表格,及对应的提示语句;//读取正确的起点、终点编号,若不正确则提示,返回重新输入;//调用chto_string(char a),在编号旁,显示其对应的景点名称;//调用void Dijkstra(int s,int t),求最短路径;//调用void output(int s,int t) 输出对应的路径信息;//return true;}if(退出) return false;}int main(){//调用init(),初始化;//显示主菜单内容;//读取操作序号;//调用bool menu(int step),进行相应的功能;//if(menu的结果为false)则退出程序,否则重复进行;}四、调试分析1、打印表格的时候,输出有部分出现乱码。
数据结构课程设计实验报告《校园导游咨询系统》内含程
上海电力学院数据结构C++课程设计题目: 校园导游咨询学生姓名:学号:院系:专业年级:2011年7月1日一、设计题目校园导游咨询;1、实验目的(1)熟练掌握图的创建及遍历基本操作算法。
(2)熟练掌握最短路径算法。
(3)利用图的遍历和最短路径求解技术,设计一个校园导游程序,为来访的客人提供各种信息查询服务。
2、实验内容【问题描述】设计一个校园导游程序,为来访的客人提供各种信息查询服务。
【基本要求】(1)设计你所在学校的校园平面图,所含景点不少于10个。
以图中顶点表示校内各景点,存放景点名称、代号、简介等信息;以边表示路径,存放路径长度等相关信息。
(2)为来访客人提供图中任意景点相关信息的查询。
(3)为来访客人提供图中任意景点的问路查询,即查询任意两个景点之间的一个最短的简单路径。
【测试数据】由读者根据实际情况指定。
【实现提示】一般情况下,校园的道路是双向通行的,可设校园平面图是一个无向网。
顶点和边均含有相关信息。
【选作内容】(6)扩充每个景点的邻接景点的方向等信息,使得路径查询结果能提供详尽的导向信息。
二、小组成员分工说明略三、需求分析1)运行环境(软、硬件环境)硬件环境:windows2000、windows XP、windows7 皆可;软件环境:Microsoft (R) Developer Studio (2)2)输入的形式和输入值的范围输入形式:整形数据(景点代号、路径长度、地图上的方位信息),字符串(景点名称及简介);输入值范围:景点代号为:整形0~17(共18个景点)路径长度为:整形1~10(两景点间距离,以近似1::100m比例换算,最远1km)景点名称字符串长度:整形1~15(景点名称)字符串长度为:字符数组1~50(对景点进行简要介绍)景点在地图方位图上的位置:整形0~103)输出的形式描述景点代号、景点名称、信息的关联以cout形式输出,告知来访客人,以便查询;景点信息查询结果的输出形式为cout字符串;两景点间最短路径输出形式为cout字符串符号、以及嵌套的printroad()函数以显示路径信息及方位信息,方便客人获取最佳路线;4)功能描述(1)设计学校的校园平面图,所含景点18个。
校园导游系统程序 课程设计 报告
目录1、需求分析 ................................... 错误!未定义书签。
2、设计思路 ................................... 错误!未定义书签。
3、算法设计 (1)3.1 概要设计 (1)3.1.1 程序中包含的模块 (1)3.1.2 模块间的调用关系 (2)3.2 详细设计 (2)4、测试分析 (9)4.1 主程序界面 (9)4.2 景点信息的查询 (10)4.3 最短路径查询 (11)5、总结 (11)6、参考文献 (12)7、附录 (12)1、需求分析设计一个校园导游系统程序,为来访的客人提供各种服务的信息查询。
(1).设计潍坊学院校园平面图,所含的景点不少于10个。
以图中顶点表示校内各景点,存放景点名称、代号、简介等信息;以边表示路径,存放路径长度等相关信息。
(2).为来访客人提供图中任意景点相关信息的查询。
(3).为来访客人提供图中任意景点的问路查询,即查询任意两个景点之间的一条最短的简单路径。
2、设计思路校园旅游模型是由景点和景点之间的路径组成的,所以这完全可以用数据结构中的图来模拟。
用图的结点代表景点,用图的边代表景点之间的路径。
所以首先应设计一个图类。
结点值代表景点信息,边的权值代表景点间的距离。
结点值及边的权值用顺序表存储,所以需要设计一个顺序表类。
本系统需要查询景点信息和求一个景点到另一个景点的最短路径长度及路线,为方便操作,所以给每个景点一个代码,用结构体类型实现。
计算路径长度和最短路线时可用弗洛伊德(Floyd)算法实现。
最后用switch选择语句选择执行浏览景点信息或查询最短路径。
3 算法设计3.1 概要设计3.1.1 程序中包含的模块(1)主程序模块主函数:void main()打印菜单,景点,景点信息(2)查询模块景点信息查询:void introduce()最短路径查询:要查找的两景点的最短距离:int shortestdistance()用floyd算法求两个景点的最短路径:void floyd()(3)打印模块打印两个景点的路径及最短距离:void display(int i,int j)3.1.2模块间的调用关系主函数main()调用:void introduce()/*景点介绍*/int shortestdistance()/*要查找的两景点的最短距离*/ shorestdistance()调用:void floyd()/*用floyd算法求两个景点的最短路径*/void display(int i,int j) /* 打印两个景点的路径及最短距离*/3.2 详细设计/*定义符号变量/*#define INT_MAX 10000#define n 10/*定义全局变量*/int cost[n][n]; /* 边的值*/int shortest[n][n]; /* 两点间的最短距离*/int path[n][n]; /* 经过的景点*/string M[100]; /*景点名称*/string J[100]; /*景点介绍*//*自定义函数原型说明*/void introduce();int shortestdistance();void floyd();void display(int i,int j);定义各顶点之间的距离:for(i=0;i<=n;i++)for(j=0;j<=n;j++)cost[i][j]=INT_MAX;cost[1][2]=cost[2][1]=3;cost[2][3]=cost[3][2]=1;cost[3][4]=cost[4][3]=2;cost[4][5]=cost[5][4]=1;cost[5][6]=cost[6][5]=1;cost[3][6]=cost[6][3]=2;cost[1][4]=cost[4][1]=5;cost[1][7]=cost[7][1]=7;cost[4][7]=cost[7][4]=1;cost[7][5]=cost[5][7]=1;cost[7][8]=cost[8][7]=2;cost[8][9]=cost[9][8]=1;cost[5][9]=cost[9][5]=2;cost[8][5]=cost[5][8]=2;cost[8][10]=cost[10][8]=1;cost[1][1]=cost[2][2]=cost[3][3]=cost[4][4]=cost[5][5]=0;cost[6][6]=cost[7][7]=cost[8][8]=cost[9][9]=cost[10][10]=0;界面菜单设计:while(1){printf("-------------------欢迎使用校园导游系统!-------------------\n");printf(" 欢迎来到潍坊学院!祝您旅途愉快! \n");printf(" 菜单选择\n");printf("1.景点信息查询\n");printf("2.景点最短路径查询\n");printf("3.退出系统\n\n");printf(" 学校景点列表(以下是您可能要去的地方):\n");printf("1:潍坊学院大门");printf("2:行政楼");printf("3:餐厅");printf("4:实验楼");printf("5:图书馆\n");printf("6:商业区");printf("7:教学楼");printf("8:篮球场");printf("9:体育馆");printf("10:弘德湖\n");printf("-----------------------------------------------------------\n");printf("请选择服务:");scanf("\n%c",&k);switch(k){case '1':printf("进入景点信息查询:");introduce();break;case '2':printf("进入最短路径查询:");shortestdistance();break;case '3':printf("谢谢使用本系统!\n");exit(0);default:printf("输入信息错误!\n请输入字母1或2或3.\n");break;}}介绍景点:void introduce(){int a;printf("您想查询哪个景点的详细信息?\n请输入景点编号:");scanf("%d",&a);getchar();printf("\n");switch(a){case 1:printf("1:学校大门\n\n学校的正门,气势宏伟。
校园导游咨询管理系统软件设计报告书
课程设计题目校园导游咨询管理系统软件设计学院计算机科学与技术学院专业计算机科学与技术班级计算机0804班姓名王成鹏指导教师杜薇2012 年 1 月9 日课程设计任务书学生姓名:王成鹏专业班级:计算机0804指导教师:杜薇工作单位:计算机学院题目:校园导游咨询管理系统软件设计初始条件:1.预备内容:数据结构(图),软件工程,面向对象程序设计,数据库技术,编译原理,可视化编程2.实践准备:掌握一种计算机高级语言等相关的使用。
要求完成的主要任务:基本功能要求:(1)设计你所在学校的校园平面图,所含景点不少于10个。
将校内各景点的数据(景点名称、代号、简介等信息)和图片以图结构表示并保存于数据库。
(2)为来访客人提供任意景点相关信息的查询。
(3)为来访客人提供任意景点的问路查询。
(4)测试数据:自定。
(5)涉及技术工具:软件工程技术、数据库技术、UML工具、Java语言或C#语言等设计报告内容应说明:1.课程设计目的与功能;2.需求分析,数据结构或模块说明(功能与框图);3.源程序的主要部分;4.运行结果与运行情况分析;5.自我评价与总结时间安排:本学期第17-19周:1.查阅、消化资料,系统调查2天2.系统分析(采用UML工具) 3天3.总体设计,实施计划(采用UML工具) 3天?4.系统开发与实现(用指定语言工具) 5天5.撰写报告2天指导教师签名:2011年12月25日系主任(或责任教师)签名:年月日校园导游咨询管理系统1.课程设计目的与功能1)设计目的:为游客设计一个校园导游咨询管理系统软件,帮助游客很好地了解校园景点位置,为观光带来方便。
作为导游就是指示景点之间的距离和方向,让游客很清楚所处的位置,并且能够很快地找到方向与目的地。
软件是为了简单、易用而设计的。
2)基本功能要求:1.设计你所在学校的校园平面图,所含景点不少于10个。
将校内各景点的数据(景点名称、代号、简介等信息)和图片以图结构表示并保存于数据库。
校园导游咨询程序
实验三:校园导游咨询一、设计方案简介设计一个校园导游程序,为来访的客人提供各种信息查询服务。
1)设计你所在学校的校园平面图,2)为来访客人提供图中任意景点相关信息的查询。
3)为来访客人提供图中任意景点的问路查询,即查询任意两个景点之间的一条最短的简单路径。
二、设计题目实现:实际需求1)设计你所在学校的校园平面图,所含景点不少于10个。
以图中顶点表示校园内各景点,存放景点名称、代号、简介等信息:以边表示路径,存放路径长度等相关信息。
2)为来访客人提供图中任意景点相关信息的查询。
3)为来访客人提供图中任意景点的问路查询,即查询任意两个景点之间的一条最短的简单路径。
2)概要设计1、校园全景一览图、显示出校园的平面图。
2、提供校园中任意景点问路查询,即求任意两个景点之间的所有路径。
3、提供校园图中多个景点的最佳访问路线查询,即求途径这过个景点的最佳(短)路径。
1.功能模块图;void Map();//校园地图void CreateGraph();//创建图void OutputPlace();//输出景点列表void SearchPlace();//查询景点信息void SearchPath();//查询最短路径void Shortpath(int i);//计算最短路径void Output(int sight1,int sight2);//输出函数2.各个模块详细的功能描述。
Map();//显示校园整体的地图、包含学校各景点的详细位置CreateGraph();//创建图、主要用来保存各景点信息OutputPlace();//输出景点列表、供选择景点信息查询时使用SearchPlace();//查询景点信息、景点的名称及介绍SearchPath();//查询最短路径、两景点间最短距离Shortpath(int i);//计算两景点间最短路径Output(int sight1,int sight2);//输出两景点最短路径及信息四.详细设计1.功能函数的调用关系图2.各功能函数的数据流程图全局变量Graph G;int path[NUM][NUM];int D[NUM];3.重点设计及编码重点设计:求最短路径编码:void Shortpath(int num)//迪杰斯特拉算法最短路径{int v,w,i,t;//i、w和v为计数变量//t表示景点个数int final[NUM]; //标志数组、用来存放顶点的信息int min;//记录权值、最终输出路径for(v=0;v<NUM;v++){final[v]=0; //假设从顶点num到顶点v没有最短路径D[v]=G.arc[num][v].length;//将num到其余顶点的最短路径长度初始化为权值for(w=0;w<NUM;w++)path[v][w]=0;//初始化从v到w的路径值if(D[v]<MAX) //存在路径{path[v][num]=1; //存在标志置为一path[v][v]=1; //自身到自身}}D[num]=0;//初始化新路径final[num]=1; //初始化num顶点属于final集合//开始主循环,每一次求得num到某个顶点的最短路径,并将其加入到final集合for(i=0;i<NUM;++i) // 其余G.vexnum-1个顶点{min=MAX; //当前所知离顶点num的最近距离for(w=0;w<NUM;++w)if(!final[w]) //w顶点在v-s中if(D[w]<min) //w顶点离num顶点更近{v=w;min=D[w];}final[v]=1; //离num顶点更近的v加入到s集合for(w=0;w<NUM;++w) //更新当前最短路径极其距离if(!final[w]&&((min+G.arc[v][w].length)<D[w]))//不在s集合,并且比以前所找到的路径都短就更新当前路径{D[w]=min+G.arc[v][w].length;//更新路径for(t=0;t<NUM;t++)path[w][t]=path[v][t];path[w][w]=1;}}}void Output(int sight1,int sight2) // 输出函数{int a,b,c,d,q=0;//a、b、c和d为计数变量//q控制计数变量、用于换行a=sight2; //将景点二赋值给aif(a!=sight1) // 如果景点二不和景点一输入重合,则进行...{printf("\t\t\t\t\t\t从%s到%s的最短路径是:\n\n\t\t\t\t\t",G.vertex[sight1].name,G.vertex[sight2].name);//输出提示信息//输出sight1到sight2的最短路径长度,存放在D[]数组中printf("\t%s",G.vertex[sight1].name); //输出景点一的名称d=sight1; //将景点一的编号赋值给dfor(c=0;c<NUM;++c){gate:; //标号,可以作为goto语句跳转的位置path[a][sight1]=0;for(b=0;b<NUM;b++){if(G.arc[d][b].length<MAX&&path[a][b]) //如果景点一和它的一个临界点之间存在路径且最短路径{printf("--->%s",G.vertex[b].name); //输出此节点的名称q=q+1; //计数变量加一,满8控制输出时的换行path[a][b]=0;d=b; //将b作为出发点进行下一次循环输出,如此反复if(q%14==0) printf("\n");goto gate;}}}printf("\n\n\t\t\t\t\t\t最短距离为%dm.\n\n\t",D[a]);}}五.测试数据及运行结果系统主界面学校平面图学校景点图最短路径信息查询异常信息三、设计评述:设计者对本设计的评述及通过设计的收获体会1.改进方案系统还有部分漏洞未能修复、不够绝对的稳定、还需改进!求最短路径时可以采用比较简单的哈密尔顿算法。
课程设计校园导游咨询
课程设计校园导游咨询一、教学目标本课程旨在让学生了解和掌握校园导游的基本知识,包括校园的历史、文化、建筑、景观等方面的内容。
通过本课程的学习,使学生能够熟练运用所学的知识,为游客提供专业的校园导游服务。
具体目标如下:1.知识目标:学生能够掌握校园的基本历史、文化、建筑和景观知识,了解校园的发展历程和特色。
2.技能目标:学生能够运用所学的知识,进行校园导游的讲解和服务,具备良好的沟通和应变能力。
3.情感态度价值观目标:学生能够培养对校园文化的认同感,增强爱护校园环境的责任心,提高服务他人的意识。
二、教学内容本课程的教学内容主要包括以下几个方面:1.校园历史:介绍校园的创建背景、发展历程和重要事件。
2.校园文化:阐述校园的文化传统、校训、校风等核心价值观。
3.校园建筑:解析校园主要建筑的风格、特点和背后的故事。
4.校园景观:介绍校园内的风景名胜、历史遗迹和生态景观。
5.导游技巧:教授导游的基本礼仪、沟通技巧、应急处理等实际操作能力。
三、教学方法为了提高教学效果,本课程将采用多种教学方法相结合的方式进行:1.讲授法:教师讲解校园历史、文化、建筑和景观等方面的知识。
2.讨论法:学生分组讨论校园导游的实际案例,分享心得体会。
3.案例分析法:分析校园导游的成功案例和存在的问题,提高学生的判断和分析能力。
4.实验法:学生进行校园导游的实践活动,锻炼学生的实际操作能力。
四、教学资源为了支持教学内容和教学方法的实施,我们将准备以下教学资源:1.教材:选用权威、实用的校园导游教材,为学生提供系统的理论知识。
2.参考书:提供相关的历史、文化、建筑等领域的参考书籍,丰富学生的知识储备。
3.多媒体资料:制作精美的课件、视频等多媒体资料,增强课堂教学的趣味性和生动性。
4.实验设备:配备必要的实验设备,如地图、模型等,帮助学生更好地理解校园景观。
5.实践活动:学生进行校园导游的实际操作,提高学生的实践能力。
五、教学评估为了全面、客观地评估学生的学习成果,本课程将采用多种评估方式相结合的方法:1.平时表现:评估学生在课堂上的参与度、发言积极性以及团队合作表现等。
校园导游程序报告
实验四校园导游程序指导教师签名:__________ 成绩:__________一、问题描述问题描述:用无向图表示你所在学校的校园景点平面图,图中顶点表示主要景点,存放景点的编号、名称、简介等。
设计要求:1.查询各景点的相关信息;2.查询图中任意两个景点间的最短路径;3.查询图中任意两个景点间的所有路径二、算法说明1.数据结构说明typedef struct{int NO; //景点序号char name[10]; //景点名称char jianjie[M*2]; //景点介绍}Adjst; //景点信息结点typedef struct ArcNode{int NO; //景点序号float distance; //邻接景点间距离ArcNode *Nnext; //某景点的另一邻接景点}ArcNode; //景点邻接表typedef struct PreNode{int AimId; //目的地序号float Adistance; //总距离int *path; //路径int lenth ; //路径长度struct PreNode *next; //下一个路径}PathNode;typedef struct HeadLink{Adjst S; //景点全部信息ArcNode *Nnext; //该景点邻接景点PathNode *PathColl; //该景点到其余景点的路径集合}HeadLink; //景点头表typedef struct TU{int Num; //景点个数HeadLink *scenicSpot; //景点头表}TU; //景区2.算法说明这个程序是实现图的最短路径而设计的;其中涉及到图的创建、图的查询、以及各种算法!首先该程序是利用链表的结构来创建图的,用的是邻接链表来实现图的各个结点来联系。
在功能菜单中运用for循环来实现各个功能的选择!1:图的创建邻接表的创建是利用链表的尾插法来将各个结点的邻接结点插入;用for循环来实现将各个顶点按照编号实现信息的创建!同时利用循环将各个路径数组和结点结点遍历的标志初始化!利用while循环输出所有景点信息!2:所有路径查询输入两景点的序号,利用深度优先遍历将所有可能的情况保存;将通过的路径存在路径数组中在setpath()函数中实现,在利用标志来判断景点是否遍历过,进行深度优先遍历;利用递归将所有可能的情况列出,其中将遍历的所有结果记录在数组中;输出所有结果。
最新数据结构校园导游咨询系统课程设计报告及课程总结.
姓名:班级:学号:指导教师:2012年12月目录1、需求分析 (1)1.1 系统简介 (1)1.2 系统功能模块介绍 (1)2、概要设计 (2)2.1 系统功能结构图 (2)2.2 系统流程图 (2)2.3 主要函数概要设计 (3)2.3.1 主函数概要设计 (3)2.3.2 初始化图函数InitGraph() (4)2.3.4 查询景点信息函数设计SearchGraph() (4)2.3.5 显示图中信息函数设计ShowGraph() (4)2.3.6 弗洛伊德算法函数设计Floyd() (5)3、详细设计 (5)3.1 主函数详细设计 (5)3.2初始化图函数详细设计InitGraph() (6)3.3查询景点信息函数详细设计SearchGraph() (7)3.4 弗洛伊德算法函数详细设计Floyd() (8)4、调试分析 (9)4.1 显示主界面函数测试 (9)4.2 查找两景点间最短路径测试 (10)4.3 查看景点信息测试 (11)5.课程设计总结 (12)6、附录 (13)1、需求分析1.1 系统简介随着现代社会生活节奏的加快,人们外出旅行以寻求放松的时间越来越多。
考虑到游客不可能对所有景点都有所了解,因此可能无法找到游玩景点最省时,最高效的路径,而人工导游成本又过高,故使用C语言,基于《数据结构》中图的相关算法开发了“江西农业大学校园咨询系统”。
开发本系统目的在于为来访我校的游客提供一条最短游览路径,本系统从实际出发,通过对校园平面图的分析,将其转化为数据并保存在系统中,因此系统提供的路径具有较大的可信性。
本系统界面友好,提示信息充分,在实际使用过程中运行良好。
1.2 系统功能模块介绍本系统主要分为以下三大功能模块:1、查询两景点最短路径:用户在选择此功能模块后,按照屏幕上方提示的景点名称及其对应的编号,要求用户输入起点和终点的编号,系统将在已存储的景点中进行匹配,若未找到所需查询的景点编号,系统将提示错误并要求用户再次输入。
校园导游系统课程设计报告
南京航空航天大学《数据结构》课程设计报告校园导游系统目录一、需求分析 (2)二、程序的主要功能 (2)三、程序运行平台 (2)四、数据结构 (2)五、算法设计思想及时间复杂度 (2)六、测试用例及结果 (5)七、存在的不足与对策及编程体会 (6)八、程序源代码 (6)一、需求分析南航学生家长及入学新生很需要一个导游程序,来引领他们参观和了解南航。
二、程序的主要功能1、查询各景点的相关信息2、查询任意两景点间的所有路径3、查询任意两景点间的最短路径 1、增加景点4、推荐参观路线 2、删除景点5、更新导游信息(操作需管理员密码) 3、更新道路信息6、对景点联通性的浏览(2阶矩阵表示)4、更新景点信息7、学校全景一览 5、修改管理员密码三、程序运行平台Microsoft Visual C++ 6.0四、数据结构图的邻接矩阵存储表示,栈的顺序存储表示五、算法设计思想及时间复杂度主要函数介绍:1、求两点间的所有路径:a)相关函数:void dfs(MGraph G,SqStack path,int *used,int u,int w);//深度优先遍历b)主要算法思想:栈的相关操作+深度优先搜索创建一个空栈保存路径,一个空数组保存已标记节点,首先让起点进栈,并标记为已访问,然后调用深度优先搜索,如果该顶点的相邻顶点(即与其有直接通路的顶点)未被访问过就标记为已访问,进栈,然后对它调用深度优先搜索,依次类推,直到获得所有到指定终点的路径。
c)时间复杂度:O(VE),其中V为图的顶点数目,E为图中边的数目。
2、求两点间的最短路径:a)相关函数:void ShortestPath(MGraph G,int v0,int P[][Nmax],int *D);//查询任意两景点间的最短路径void PrintShortest(MGraph G,int v1,int v2,int P[][Nmax],int *D); //输出最短路径b)主要算法思想:迪杰斯特拉算法假设起点为v0,S为已找到的从v0出发的最短路径的终点的集合,其初始状态为空集。
校园导游系统程序 课程设计 报告-推荐下载
目录 1、需求分析....................................................................1 2、设计思路....................................................................1 3、算法设计....................................................................1
3.1.2 模块间的调用关系
主函数 main()调用: void introduce()/*景点介绍*/ int shortestdistance()/*要查找的两景点的最短距离*/
shorestdistance()调用: void floyd()/*用 floyd 算法求两个景点的最短路径*/ void display(int i,int j) /* 打印两个景点的路径及最短距离
2、设计思路
校园旅游模型是由景点和景点之间的路径组成的,所以这完全可以用数据结 构中的图来模拟。用图的结点代表景点,用图的边代表景点之间的路径。所以 首先应设计一个图类。结点值代表景点信息,边的权值代表景点间的距离。结 点值及边的权值用顺序表存储,所以需要设计一个顺序表类。本系统需要查询 景点信息和求一个景点到另一个景点的最短路径长度及路线,为方便操作,所 以给每个景点一个代码,用结构体类型实现。计算路径长度和最短路线时可用 弗洛伊德(Floyd)算法实现。最后用 switch 选择语句选择执行浏览景点信息或 查询最短路径。
/* 边的值*/ /* 两点间的最短距离*/ /* 经过的景点*/ /*景点名称*/ /*景点介绍*/
2
对全部高中资料试卷电气设备,在安装过程中以及安装结束后进行高中资料试卷调整试验;通电检查所有设备高中资料电试力卷保相护互装作置用调与试相技互术通关,1系电过,力管根保线据护敷生高设产中技工资术艺料0不高试仅中卷可资配以料置解试技决卷术吊要是顶求指层,机配对组置电在不气进规设行范备继高进电中行保资空护料载高试与中卷带资问负料题荷试2下卷2,高总而中体且资配可料置保试时障卷,各调需类控要管试在路验最习;大题对限到设度位备内。进来在行确管调保路整机敷使组设其高过在中程正资1常料中工试,况卷要下安加与全强过,看度并22工且22作尽22下可22都能22可地护以缩1关正小于常故管工障路作高高;中中对资资于料料继试试电卷卷保破连护坏接进范管行围口整,处核或理对者高定对中值某资,些料审异试核常卷与高弯校中扁对资度图料固纸试定,卷盒编工位写况置复进.杂行保设自护备动层与处防装理腐置,跨高尤接中其地资要线料避弯试免曲卷错半调误径试高标方中高案资等,料,编试要5写、卷求重电保技要气护术设设装交备备置底4高调、动。中试电作管资高气,线料中课并敷3试资件且、设卷料中拒管技试试调绝路术验卷试动敷中方技作设包案术,技含以来术线及避槽系免、统不管启必架动要等方高多案中项;资方对料式整试,套卷为启突解动然决过停高程机中中。语高因文中此电资,气料电课试力件卷高中电中管气资壁设料薄备试、进卷接行保口调护不试装严工置等作调问并试题且技,进术合行,理过要利关求用运电管行力线高保敷中护设资装技料置术试做。卷到线技准缆术确敷指灵设导活原。。则对对:于于在调差分试动线过保盒程护处中装,高置当中高不资中同料资电试料压卷试回技卷路术调交问试叉题技时,术,作是应为指采调发用试电金人机属员一隔,变板需压进要器行在组隔事在开前发处掌生理握内;图部同纸故一资障线料时槽、,内设需,备要强制进电造行回厂外路家部须出电同具源时高高切中中断资资习料料题试试电卷卷源试切,验除线报从缆告而敷与采设相用完关高毕技中,术资要资料进料试行,卷检并主查且要和了保检解护测现装处场置理设。备高中资料试卷布置情况与有关高中资料试卷电气系统接线等情况,然后根据规范与规程规定,制定设备调试高中资料试卷方案。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
数据结构课程设计设计题目:校园导游咨询学院:信息学院班级:计算机1008班姓名:学号: 20101221180 日期: 2012 年 3 月校园导航问题[问题描述]设计一个校园导游程序,为来访的客人提供各种信息查询服务。
[基本要求](1)设计所在学校的校园平面图,所含景点不少于十个。
以图中顶点表示校内各景点,存放景点名称、代号、简介等信息;以边表示路径,存放路径长度等信息。
(2)为来访客人提供图中任意景点相关信息的查询。
(3)为来访客人提供图中任意景点的问路查询,即查询任意两个顶点之间的一条最短的简单路径。
(4)校园导游图的景点和道路的修改扩充功能。
(5)扩充道路信息,如道路类别(车道、人行道),以致可按客人所需分别查询人行路径或车行路径。
(6)扩充每个景点的林洁景点的方向等信息,使得路径查询结果能提供详尽的导向信息。
(7)实现校园导游的仿真界面。
校园导航问题 (2)一、概要设计 (4)二、详细设计 (6)三、调试分析 (12)四、调用关系 (12)五、用户操作指南 (13)[测试数据]一、概要设计1. 数据类型#define V_MAX 20#define E_MAX 200typedef struct {char name[10];//名字//char code[10];//代码char info[20];//信息,简介int x,y;//坐标}VType;//顶点类型typedef struct {int live;//标记是否存在,如果被删除则为0,存在为1char name[10];// 路名int length;//路的长度char ivex[10],jvex[10];//路(边)连接的两个顶点的名字int type;//表示道路类型,0表示两个都是,1表示人行道,2表示行车道}EdgeType;//边类型typedef struct AdjNode{int length;// 弧的长度char name[10];//关联的顶点的名字struct AdjNode *next;//下一条弧}AdjNode;//弧结点typedef struct {int live;//标记是否存在,如果被删除则为0,存在为1int flag;//标记是否被访问过VType data;//顶点的信息AdjNode *first_adj;//指向该顶点的第一条弧}VNode;//景点(顶点)结点typedef struct {VNode vex[V_MAX];//顶点数组EdgeType edge[E_MAX];//边的数组int v_num,e_num;}Graph;//图类型////////////////////////////////Graph G;AdjNode *p;2.基本函数////////////////////////////////void creatGraph(Graph &G);//创建校园图void load(Graph &G);//从文件中读取数据void save(Graph &G);//保存数据入文件int find_v(Graph G,char name[10]);//通过输入景点名字,返回该景点在vex数组里的下标void print_Graph(Graph G);//以邻接矩阵的形式输出图信息int direction(Graph G,char bname[10],char fname[10]);//用于判断并输出一个景点在另外一个景点的方位信息void search_view(Graph G);//查询并输出景点的所有信息void del_v(Graph &G);//删除景点void add_v(Graph &G);//增加景点void add_e(Graph &G)//增加道路void modify_v(Graph &G);//修改景点信息void del_e(Graph &G);//删除道路二、详细设计本程序由m.cpp、head.h、Menu.h、dijie.h4个文件构成。
1、m.cpp主要用于调用菜单函数#include <stdio.h>#include <stdlib.h>#include <malloc.h>#include <string.h>#include "head.h"#include "dijie.h"#include "allpath.h"#include "Menu.h"void main(){load(G);// while(1)menu();}2.Menu.h存放用于显示系统仿真界面的函数void mobifyMenu(){while(1){system("cls");int choose;printf("------------------------------------------");printf("\n");printf(" 校园导游系统 ");printf("\n");printf("------------------------------------------");printf("\n");printf(" 景点或者道路信息的修改扩充 ");printf("\n");printf("\n");printf("------------------------------------------");printf("\n");printf("1. 增加新景点\n");printf("2. 删除景点\n");printf("3. 修改景点\n");printf("4. 增加新道路\n");printf("5. 重新构建校园景点和路径信息\n");printf("0. 返回上一个菜单\n");printf("请输入操作代码:");scanf("%d",&choose);getchar();system("cls");switch(choose){case 1:{add_v(G);break;}case 2:{del_v(G);break;}case 3:{modify_v(G);break;}case 4:{add_e(G);break;}case 5:{creatGraph(G);break;}case 0:return;}}}void menu(){int choose;printf("------------------------------------------");printf("\n");printf(" 校园导游系统 ");printf("\n");printf("------------------------------------------");printf("\n");printf(" 景点预览 ");printf("\n");for(int i=0;i<G.v_num;i++){printf(" %s ",G.vex[i]);if((i+1)%2==0) printf("\n");}printf("\n");// print_Graph(G);printf("------------------------------------------");printf("\n");printf("1. 景点或者道路信息的修改扩充\n");printf("2. 查询景点信息\n");printf("3. 查询最佳观光路径\n");printf("0. 退出系统\n");printf("请输入操作代码:");scanf("%d",&choose);getchar();system("cls");switch(choose){case 1:{mobifyMenu();break;}case 2:{search_view(G);getchar();break;}case 3:{FDijkstra(G);getchar();break;}case 0:{exit(0);break;}}system("cls");}3.head.h本文件用于存放基本操作函数,在此不做详细介绍4.dijie.h本文件用于查询并输出两个景点间的最佳路径并输出const int maxnum = 20;const int maxint = 10000;int c[maxnum][maxnum];//图的邻接矩阵int P[ maxnum][ maxnum];//标明最短路径经过哪个点bool final[maxnum];//标明从原点到某个点的最短路径已经找到int D[maxnum];//记录最短路径的长度int path[maxnum],jishu=0;//path用于按顺序存放已找到最短路径的顶点,path[1]为第二个已经找到的//需要注意的是,如果图中有9个顶点,其中有两个无法到达,则path的最后面3个就是重复的//要注意区分开// 用迪杰斯特拉算法找出最短路径void DIJ(Graph G,int v0,int P[ maxnum][ maxnum],int D[maxnum]){jishu=0;int min;for(int v=0;v<G.v_num;v++){final[v]=false; D[v]=c[v0][v];for(int w=0;w<G.v_num;++w) P[v][w]=0;if(D[v]<maxint) {P[v][v0]=1;P[v][v]=1;}}D[v0]=0;final[v0]=true;path[jishu]=v0;jishu++;for(int i=1;i<G.v_num;++i){min=maxint;for(int w=0;w<G.v_num;++w)if(!final[w])if (D[w]<min) {v=w;min=D[w];}final[v]=true;path[jishu]=v;jishu++;for(w=0;w<G.v_num;++w)if(!final[w]&&(min+c[v][w]<D[w])){D[w]=min+c[v][w];// P[w]=P[v];for(int j=0;j<G.v_num;j++)P[w][j]=P[v][j];P[w][w]=1;}}//纠正jishufor(jishu=1,i=1;i<G.v_num;i++)if(path[i]==path[i-1]) break;else jishu++;}// 输出最短路径void print_path(Graph G,int b_v,int f_v){if(D[f_v]>1000) {printf("没有能够到达的路径\n");return ;}int shortPath[V_MAX],count=0;//count指最短路径里到底有几个点// shortPath里面是正确连续的最短路径//若果shortPath={0,4,3,5},则最短路径为0->4->3->5shortPath[0]=b_v;for(int i=1;i<jishu;i++){if(P[f_v][path[i]]==1) // 问题出在path[i]上,由于有两个景点是无法到达的// 所以path[i]后面三个元素都是重复的,导致count数多了2个{count++;shortPath[count]=path[i];//puts(G.vex[path[i]]);}}// 通过shortPath输出路线信息int road[V_MAX];//road[0]记录的是从shortPath[0]到shortPath[1]要走的路for(i=0;i<count;i++) //i指向两个邻接点的起点,i+1表示终点for(int j=0;j<G.e_num;j++) //找连接这两个顶点的边,j指向边{if(strcmp(G.edge[j].ivex,G.vex[shortPath[i]])==0&&strcmp(G.edge[j].jv ex,G.vex[shortPath[i+1]])==0){ road[i]=j;break; }if(strcmp(G.edge[j].jvex,G.vex[shortPath[i]])==0&&strcmp(G.edge[j].iv ex,G.vex[shortPath[i+1]])==0){ road[i]=j;break; }}printf("从 ");for(i=0;i<count;i++){printf("%s\n",G.vex[shortPath[i]]);printf("往");direction(G,G.vex[shortPath[i]],G.vex[shortPath[i+1]]);printf(" 沿着%s路走%d 米到\n",G.edge[road[i]].name,G.edge[road[i]].length);}puts(G.vex[f_v]);}// 查询两个景点间最短路径函数void FDijkstra(Graph G){int vi,vj;char begin_p[10],final_p[10];int b_v,f_v;for(int g=0;g<G.v_num;g++)for(int h=0;h<G.v_num;h++)c[g][h]=maxint;for(int h=0;h<V_MAX;h++)for(g=0;g<V_MAX;g++)P[g][h]=0;for( h=0;h<V_MAX;h++)final[h]=false;for(h=0;h<V_MAX;h++)D[h]=10000;for(h=0;h<V_MAX;h++)path[h]=0;jishu=0;int t;printf("选择道路类型(人行道1/行车道2/两者都行0):"); scanf("%d",&t);getchar();// 构建邻接矩阵for(int i=0;i<G.e_num;i++){if(G.edge[i].type==t||G.edge[i].type==0){vi=find_v(G,G.edge[i].ivex);vj=find_v(G,G.edge[i].jvex);c[vi][vj]=G.edge[i].length;c[vj][vi]=G.edge[i].length;}}printf("请输入起点:");while(1){gets(begin_p);if(find_v(G,begin_p)==100){printf("不存在该景点,请重新输入:");continue;}break;}b_v=find_v(G,begin_p);printf("请输入终点:");while(1) {gets(final_p);if(find_v(G,final_p)==100) {printf("不存在该景点,请重新输入:"); continue; }break; }f_v=find_v(G,final_p); DIJ(G,b_v,P,D);print_path(G,b_v,f_v);}三、调试分析数据结构书中的迪杰斯特拉算法只能求出最短路径中有哪个景点,但无法求出这几个景点的经过顺序,所以先利用迪杰斯特拉算法记录下某个顶点求出到最短路径的顺序,然后再比对哪几个景点是最短路径里所经过的得出最短路径及景点路过的顺序。