校园导游系统.doc

上传人:M****1 文档编号:560870003 上传时间:2023-03-26 格式:DOC 页数:8 大小:32.01KB
返回 下载 相关 举报
校园导游系统.doc_第1页
第1页 / 共8页
校园导游系统.doc_第2页
第2页 / 共8页
校园导游系统.doc_第3页
第3页 / 共8页
校园导游系统.doc_第4页
第4页 / 共8页
校园导游系统.doc_第5页
第5页 / 共8页
点击查看更多>>
资源描述

《校园导游系统.doc》由会员分享,可在线阅读,更多相关《校园导游系统.doc(8页珍藏版)》请在金锄头文库上搜索。

1、校园导游系统/ 校园导游咨询 /*问题描述 设计一个校园导游程序,为来访的客人提供各种信息查询服务。 基本要求 (1)设计你的学校的校园平面图,所含景点不少于10个。以图中顶点表示校内各景点,存放景点名称、代号、简介等信息;以边表示路径,存放路径长度等相关信息。 (2)为来访客人提供图中任意景点相关信息的查询。 (3)为来访客人提供图中任意景点的问路查询,即查询任意两个景点之间的一条最短的简单路径。 实现提示 一般情况下,校园的道路是双向通行的,可设校园平面图是一个无向网。顶点和边均含有相关信息。 一需求分析 1从武汉理工大学余家头校区平面图中选取10个大家熟悉的景点,抽象成一个无向带权图(如

2、图所示)。以图中顶点表示景点,边上的权值表示两地的距离。 2本程序的目的是为用户提供路径咨询和景点查询。根据用户指定的始点和终点输出相应路径或者根据用户指定的景点输出景点的信息。 二、概要设计 1本文采用的数据结构 */ /*包含头文件*/ / 数据结构课程设计.cpp : 定义控制台应用程序的入口点。/#include stdafx.h#include #include /定义符号常量#define INT_MAX 10000 #define n 10 /定义全局变量int costnn;/ 边的值 int shortestnn;/两点间的最短距离 int pathnn;/ 经过的景点voi

3、d introduce(); /自定义函数原型说明int shortestdistance(); void floyed(); void display(int i,int j); /* (1)景点信息查询 (2)两景点的最短距离 (3)两个景点之间的路径 三、详细设计 */ void main() /主函数 int i,j; char k; for(i=0;i=n;i+) for(j=0;j10的数字编号!nn); break; /*introduce*/ int shortestdistance() /*要查找的两景点的最短距离*/ int i,j; printf(请输入要查询的两个景点的

4、编号(1-10的数字编号并用,间隔):); scanf(%d,%d,&i,&j); if(in|in|j10的数字编号并用,间隔):n); scanf(%d,%d,&i,&j); else floyed(); display(i,j); return 1; /*shortestdistance*/ void floyed() /*用floyed算法求两个景点的最短路径*/ int i,j,k; for(i=0;i=n;i+) for(j=0;j=n;j+) shortestij=costij; pathij=0; for(k=1;k=n;k+) for(i=1;i=n;i+) for(j=1;

5、j(shortestik+shortestkj) /*用path记录从i到j的最短路径上点j的前驱景点的序号*/ shortestij=shortestik+shortestkj; pathij=k; pathji=k; /*floyed*/ void display(int i,int j) /* 打印两个景点的路径及最短距离 */ int a,b; a=i; b=j; printf(您要查询的两景点间最短路径是:nn); if(shortestij!=INT_MAX) if(ij) printf(%d,b); while(pathij!=0) /* 把i到j的路径上所有经过的景点按逆序打印出来*/ printf(-%d,pathij); if(ij) j=pathij; else i=pathji; printf(%d)最短距离是:%d米nn,a,b,shortestab); else printf(%d,a); while(pathij!=0) /* 把i到j的路径上所有经过的景点按顺序打印出来*/ printf(-%d,pathij); if(i%d,b); printf(nn); printf(%d-%d)最短距离是:%5d米nn,a,b,shortestab); else printf(输入错误!不存在此路!nn); printf(n); /*display*/

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 生活休闲 > 社会民生

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号