安工程校园导游系统课程设计报告

2023-12-25 10:28

本文主要是介绍安工程校园导游系统课程设计报告,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

第一章 概述

1.1 问题描述

根据题目内容,需要用无向网表示所在学校的景点平面图,即校内每个景点

为无向网中的各个结点,景点的编号、名称、简介等信息存储在结点中,图中的 边表示景点间的道路,存放景点之间的路径长度等信息。需要回答有关景点介绍、

游览路径等问题。具体要求为:

(1) 能够查询各个景点的相关信息。

(2) 查询图中任意两个景点间的最短路径。

(3) 查询图中任意两个景点间的所有路径。

(4) 增加、删除、更新有关景点和道路的信息。

1.1.1 问题背景

随着疫情的结束,越来越多的人选择进高校游玩,但是由于校园面积较大,游客们又对学校的路线不熟悉,凭感觉乱逛,往往参观几个景点以后就精疲力竭了。这就迫切需要一个可以为来访客人提供全方位、个性化的导览服务的校园导游程序,使他们更加方便、轻松地了解和探索学校校园。通过提供详细的景点介绍、地图导航、路线规划等功能,游客可以更好地规划自己的行程,提高旅游体验。

1.1.2 问题分析

题目要求我们使用无向网来表示一个学校的校园景点平面图,其中顶点代表主要景点,边代表景点之间的道路。我们需要实现几个基本功能:查询各景点的相关信息、查询任意两个景点间的最短路径、查询任意两个景点间的所有路径,以及增加、删除、更新有关景点和道路的信息。

为了解决这个问题,首先需要对校园的景点图信息进行收集,在百度地图中可 以搜索到相应的信息。其次是选择合适的图存储结构由于题目中提到的是无向网,考虑到查询任意两个景点间的最短路径和所有路径,邻接矩阵可能更为方便选择邻接矩阵作为图的存储结构。然后使用一个结构体或类来存储每个景点编号、名称、简介等信息。针对路径查询的问题,选择使用弗洛伊德算法来实现最短路径查询,使用深度优先搜索来实现所有路径查询。对于增加、删除和更新操作,设计相应的算法来更新图的存储结构和相关信息。

1.2 开发环境

编译器:Dev C++ 6.3    开发环境:Windows 11系统

  • 第二章 需求分析

2.1 系统要求

(1) 建立校园导游系统,提升游客的体验感。

(2) 实现查询各景点的相关信息功能。

(3) 实现查询图中任意两个景点间的最短路径和所有路径功能。

(4) 实现对景点信息的增加、删除、更新有关景点和道路的信息功能。 

2.2 系统功能

(1)主要功能:可以快速查询各景点的相关信息和任意两个景点间的最短路径和所有路径以及对景点信息的增加、删除、更新有关景点和道路的信息。

(2)具体功能:系统会提供给游客和管理员五个功能选项并指出输入方式,详细功能如下所示:

<1>安工程景点信息查询:游客输入系统所设置的对应选项即可查看景点的平面图和可查询的景点,然后输入要查询的景点的编号即可查询到该景点的全部信息。

<2>两景点之间最短路查询:游客输入系统所设置的对应选项,然后输入起点的景点编号和终点的景点编号,即可得到起点景点至终点景点的最短路径。

<3>两景点间所有路径查询:游客输入系统所设置的对应选项,然后输入起点的景点编号和终点的景点编号,即可得到起点景点至终点景点的所有路径。

<4>景点和路径信息的删除或增加(更新):管理员输入对应选项后按照系统的提示选择删或增加功能选项并进一步按照提示进行操作,即可实现景点和路径信息的删除或增加。

<0>退出系统:游客输入对应选项后即可退出本系统。

(3)系统功能结构图

图 2-1 安工程校园导游系统功能结构图

2.3 系统优缺点

(1)优点:可供使用者方便快捷地查询各景点的相关信息和任意两个景点间的最短路径和所有路径以及对景点信息的增加、删除、更新有关景点和道路的信息。操作简单易懂且系统会根据操作者所选的选项进行下一步的提示,逻辑结构十分严谨,非常实用可靠。

(2)缺点:无所满足求多个景点的最佳游览路径,导游图的界面不够仿真。

2.4 系统展望

(1)虽然它的时间复杂度为O(n^2)且只能得到近似最优解,而不是全局最优解但是对于校园景点最短路径查询这种较小规模的问题,贪婪算法通常可以得到较好的结果。故可以使用贪婪算法实现求多个景点的最佳游览路径的功能。

(2)借助QT页面开发工具来精细化导游图的仿真界面,提升用户体验感。

第三章 算法概要设计

3.1 主要算法流程

3.1.1 初始化信息模块

初始化信息模块由两个函数组成,其功能为预置校园景点图的信息,对校园景点图进行初始化,为后续操作提供基础的景点图信息。其运行过程由图3-1所示。

图 3-1初始化信息模块流程

3.1.2 景点信息查询模块

景点信息查询模块由两个函数组成,其功能为展示景点平面图并查询已有的景点信息。该模块运行时,首先输出校园平面景点图,然后输出可查询的景点及其编号,使用者之后根据提示需输入要查询的景点编号,即可查询到想了解的景点信息。模块流程如图3-2所示。

图 3-2 景点信息查询模块流程

3.1.3 Floyd最短路径求解算法

最短路径查询模块由两个函数组成,其功能为求两景点之间的最短路径。首先需要输入起点的景点编号,然后输入终点的景点编号,此模块采用弗洛伊德算法求最短路径,最后输出两景点之间的最短路径。如图3-3所示。

图 3-3最短路径查询模块流程

弗洛伊德算法(Floyd算法),也称为插点法,是一种用于寻找给定加权图中多源点之间最短路径的算法,适用于任意类型的图和边权值均为正或负的情况。该算法基于动态规划的思想,通过对任意两个顶点之间的所有中间顶点进行遍历来计算其最短路径。具体过程是,针对每对顶点i和j,如果存在k使得从i到j的路径上经过k点比不经过k点的路径更短,则更新i到j的最短路径为经过k点的路径。在遍历完所有中间节点后,就可以得到任意两个顶点之间的最短路径。其算法流程如图3-4所示。

图 3-4 弗洛伊德算法流程

3.1.4 DFS深度优先遍历求解所有路径算法

所有路径查询模块由一个函数组成,其功能为求两景点之间所有路径。此模块需要输入起点和终点的景点编号,然后通过深度优先遍历算法能够求得所有满足起点终点是使用者所输入的景点的路径并输出。如图3-5所示。

图 3-5 所有路径查询模块流程

深度优先搜索(Depth-First Search,DFS)是一种用于图和树的遍历算法,其思想是尽可能深地搜索图的分支,直到不能再继续为止,然后回溯到前一状态,继续搜索其他分支。

在深度优先搜索中,从起始节点开始,沿着一条路径不断向前探索,直到到达末端节点为止,然后返回到最近的尚未搜索完毕的节点,继续进行搜索。如此循环,直到所有节点都被访问过为止。

深度优先搜索的基本步骤为:首先访问当前节点,并将其标记为已访问。然后对当前节点的所有相邻节点中尚未访问过的节点,依次进行深度优先搜索。最后重复上述步骤,直到所有节点都被访问过为止。其算法流程如图3-6所示。

图 3-6 DFS深度优先搜索算法流程

3.1.5 删除或增加更新模块

删除或增加更新模块由下面一个函数组成,其功能为删除或增加或更新景点信息和路径信息。使用者根据模块菜单,选择输入对应功能的序号,功能 1 为增加或者更新景点信息,使用者需要输入要增加信息的景点的编号(如果景点为新增的景点编号需要在原来基础上递增)、景点名称、景点介绍。功能 2 为增加或者更新一条路径的信息,以景点编号形式输入,并赋予这条路径长度。功能3为删除景点信息,使用者只需要输入景点编号即可,程序中将该景点信息全部置 0 表示该景点已经被删除。功能 4 为删除路径信息,输入景点编号表示对应路径即可,程序中将该路径在邻接矩阵的值赋值为无穷大,表示两景点之间无路径。该模块流程如图3-7所示。

图 3-7 删除或增加更新模块流程

3.2 使用的存储结构

3.2.1 结构体类型的定义

typedef struct VexNode//景点信息结构体

{

 int vertex;//景点编号

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

 char vertax_message[400];//景点介绍

}VerNode;

typedef struct maps//景点图的结构体

{

VerNode  v[MAX];

int vexnum;//点数

int arcnum;//边数

int edgs[MAX][MAX];//邻接矩阵

}AdjList;

结构体应用题目:校园导游程序。

结构体类型成员介绍:

(1)int vertex:景点的编号

(2)char name[20]:景点的名称

(3)char vertax_message[400]:景点的介绍信息

(4)int vexnum:图的点数

(5)int arcnum:图的边数

(6)int edgs[MAX][MAX]:邻接矩阵

3.2.2 全局变量与符号常量
  1. 全局变量有:

int dist[MAX][MAX];///距离

int path[MAX][MAX];///路径

int Stack[MAX];///路径栈

int top;///栈顶

int counts;///记录路径数

int vertex;//景点编号

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

char vertax_message[400];//景点介绍

int vexnum;//点数

int arcnum;//边数

int edgs[MAX][MAX];//邻接矩阵

int visited[MAX];

应用题目:校园导游程序。

  1. 符号常量有:

#define INF 9999999

#define MAX 30

应用题目:校园导游程序

3.2.3 函数原型、功能及其参数的意义

表3-1函数简介

函数原型

函数功能

函数参数及其意义

void create_vertex(AdjList &GL);

初始化校园景点及景点信息函数

参数GL是一个AdjList类型的结构体引用,用来表示校园景点图。

void Init_Creat_maps(AdjList & GL);

初始化校园景点图函数

参数GL是一个AdjList类型的结构体引用,用来表示校园景点图。

void Dis_map();

展示校园景点图

......

void add_message(AdjList &GL);

更新或添加或删除校园景点及路径信息函数

参数GL是一个AdjList类型的结构体引用,用来表示校园景点图。

void find_message(AdjList GL);

查询景点信息函数

参数GL是一个AdjList类型的结构体引用,用来表示校园景点图。

void Floyd(AdjList GL);

弗洛伊德求最短路径

参数GL是一个AdjList类型的结构体引用,用来表示校园景点图。

void Floyd_print(int s, int e,AdjList GL);

这篇关于安工程校园导游系统课程设计报告的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/535176

相关文章

Ilya-AI分享的他在OpenAI学习到的15个提示工程技巧

Ilya(不是本人,claude AI)在社交媒体上分享了他在OpenAI学习到的15个Prompt撰写技巧。 以下是详细的内容: 提示精确化:在编写提示时,力求表达清晰准确。清楚地阐述任务需求和概念定义至关重要。例:不用"分析文本",而用"判断这段话的情感倾向:积极、消极还是中性"。 快速迭代:善于快速连续调整提示。熟练的提示工程师能够灵活地进行多轮优化。例:从"总结文章"到"用

不懂推荐算法也能设计推荐系统

本文以商业化应用推荐为例,告诉我们不懂推荐算法的产品,也能从产品侧出发, 设计出一款不错的推荐系统。 相信很多新手产品,看到算法二字,多是懵圈的。 什么排序算法、最短路径等都是相对传统的算法(注:传统是指科班出身的产品都会接触过)。但对于推荐算法,多数产品对着网上搜到的资源,都会无从下手。特别当某些推荐算法 和 “AI”扯上关系后,更是加大了理解的难度。 但,不了解推荐算法,就无法做推荐系

基于人工智能的图像分类系统

目录 引言项目背景环境准备 硬件要求软件安装与配置系统设计 系统架构关键技术代码示例 数据预处理模型训练模型预测应用场景结论 1. 引言 图像分类是计算机视觉中的一个重要任务,目标是自动识别图像中的对象类别。通过卷积神经网络(CNN)等深度学习技术,我们可以构建高效的图像分类系统,广泛应用于自动驾驶、医疗影像诊断、监控分析等领域。本文将介绍如何构建一个基于人工智能的图像分类系统,包括环境

水位雨量在线监测系统概述及应用介绍

在当今社会,随着科技的飞速发展,各种智能监测系统已成为保障公共安全、促进资源管理和环境保护的重要工具。其中,水位雨量在线监测系统作为自然灾害预警、水资源管理及水利工程运行的关键技术,其重要性不言而喻。 一、水位雨量在线监测系统的基本原理 水位雨量在线监测系统主要由数据采集单元、数据传输网络、数据处理中心及用户终端四大部分构成,形成了一个完整的闭环系统。 数据采集单元:这是系统的“眼睛”,

嵌入式QT开发:构建高效智能的嵌入式系统

摘要: 本文深入探讨了嵌入式 QT 相关的各个方面。从 QT 框架的基础架构和核心概念出发,详细阐述了其在嵌入式环境中的优势与特点。文中分析了嵌入式 QT 的开发环境搭建过程,包括交叉编译工具链的配置等关键步骤。进一步探讨了嵌入式 QT 的界面设计与开发,涵盖了从基本控件的使用到复杂界面布局的构建。同时也深入研究了信号与槽机制在嵌入式系统中的应用,以及嵌入式 QT 与硬件设备的交互,包括输入输出设

JAVA智听未来一站式有声阅读平台听书系统小程序源码

智听未来,一站式有声阅读平台听书系统 🌟&nbsp;开篇:遇见未来,从“智听”开始 在这个快节奏的时代,你是否渴望在忙碌的间隙,找到一片属于自己的宁静角落?是否梦想着能随时随地,沉浸在知识的海洋,或是故事的奇幻世界里?今天,就让我带你一起探索“智听未来”——这一站式有声阅读平台听书系统,它正悄悄改变着我们的阅读方式,让未来触手可及! 📚&nbsp;第一站:海量资源,应有尽有 走进“智听

【专题】2024飞行汽车技术全景报告合集PDF分享(附原数据表)

原文链接: https://tecdat.cn/?p=37628 6月16日,小鹏汇天旅航者X2在北京大兴国际机场临空经济区完成首飞,这也是小鹏汇天的产品在京津冀地区进行的首次飞行。小鹏汇天方面还表示,公司准备量产,并计划今年四季度开启预售小鹏汇天分体式飞行汽车,探索分体式飞行汽车城际通勤。阅读原文,获取专题报告合集全文,解锁文末271份飞行汽车相关行业研究报告。 据悉,业内人士对飞行汽车行业

【区块链 + 人才服务】可信教育区块链治理系统 | FISCO BCOS应用案例

伴随着区块链技术的不断完善,其在教育信息化中的应用也在持续发展。利用区块链数据共识、不可篡改的特性, 将与教育相关的数据要素在区块链上进行存证确权,在确保数据可信的前提下,促进教育的公平、透明、开放,为教育教学质量提升赋能,实现教育数据的安全共享、高等教育体系的智慧治理。 可信教育区块链治理系统的顶层治理架构由教育部、高校、企业、学生等多方角色共同参与建设、维护,支撑教育资源共享、教学质量评估、

软考系统规划与管理师考试证书含金量高吗?

2024年软考系统规划与管理师考试报名时间节点: 报名时间:2024年上半年软考将于3月中旬陆续开始报名 考试时间:上半年5月25日到28日,下半年11月9日到12日 分数线:所有科目成绩均须达到45分以上(包括45分)方可通过考试 成绩查询:可在“中国计算机技术职业资格网”上查询软考成绩 出成绩时间:预计在11月左右 证书领取时间:一般在考试成绩公布后3~4个月,各地领取时间有所不同

系统架构师考试学习笔记第三篇——架构设计高级知识(20)通信系统架构设计理论与实践

本章知识考点:         第20课时主要学习通信系统架构设计的理论和工作中的实践。根据新版考试大纲,本课时知识点会涉及案例分析题(25分),而在历年考试中,案例题对该部分内容的考查并不多,虽在综合知识选择题目中经常考查,但分值也不高。本课时内容侧重于对知识点的记忆和理解,按照以往的出题规律,通信系统架构设计基础知识点多来源于教材内的基础网络设备、网络架构和教材外最新时事热点技术。本课时知识