C++Qt编写校园导航系统

系统要求

(1)有界面, 显示各个景点以及景点之间的路径和路径长度,边上有几个按钮和文本框,在文本框中输入遍历的起点,输入就最短路径的起点和终点, 点击按钮后在界面上用不同颜色标注出路径或铺设线路。

(2)构造图时最少6个景点,各个景点之间的距离和路径,可以通过输入来得到 ,由此构建图, 也可以把这些信息存储到一个文件中, 通过读取文件构建图, 图可以采用邻接矩阵存储

(3)给出从某一景点出发,把所有景点都反访问一遍的所有路径(即DFS),会有多条不同的路径(如何求多条路径??), 要求在界面上显示DFS的路径,不同的路径用不同颜色标注出来。(4) 在界面上输入起点和终点,从界面上用颜色标注这两景点之间的最短路径

(5)设管道实际上就是求最小生成树,可以用PRIM或KRUSKAL 算法求最小生成树,在界面上用不同颜色标注出铺设路径

(6)鼠标点击某一景点时显示该景点的一些介绍信息和门票信息

实现内容

1.使用图的DFS算法实现以某一节点为起点,在校园中游览所有地点。

2.使用图的Dijkstra算法实现从节点A到节点B的导航。

3.使用图的DFS算法+回溯法实现以某一节点为起点的所有游览路线。

4.通过Prim算法,实现管道的铺设,即最小生成树。

5.可以动态的通过鼠标在视图区域点击添加节点。

6.可以动态的通过输入指定节点/边删除节点/边。

数据存储结构

1.通过文件存储所有景点和边的数据。

2.通过邻接表记录图的信息。

3.邻接表中的节点使用结构体构建。

4.景点的具体信息使用一个自定义类Spot存储。避免直接在邻接表中存储Spot导致消耗大量内存。

界面展示

相关推荐
胡八一12 分钟前
vs2022解决 此项目需要MFC库。从visual studio安装程序(单个组件选项卡)为正在使用的任何工具和体系结构安装他们问题
c++·mfc·visual studio
Dxy123931021620 分钟前
Python对字典列表按某个字段排序
开发语言·python
.hopeful.21 分钟前
基于QT的仿QQ音乐播放器
开发语言·c++·qt
是店小二呀23 分钟前
【优选算法-二分查找】二分查找算法解析:如何通过二段性优化搜索效率
c++·算法
giao源36 分钟前
JAVA实现将富文本内容插入已有word文档并下载(dock4j+jsoup)
java·开发语言·word
努力也学不会java37 分钟前
【网络原理】 网络编程套接字
java·开发语言·网络·网络协议·tcp/ip·php
鑫—萍42 分钟前
C++——入门基础
c语言·开发语言·c++·学习·算法
溟洵1 小时前
【C++ Qt】快速上手 显⽰类控件(Label、LCDNumber、ProcessBar、CalendarWidget)
开发语言·c++·qt
HvrI11 小时前
【Harmony_Bug】forEach + asyncawait 的异步陷阱
开发语言·华为·bug·harmonyos·鸿蒙
半青年2 小时前
单例模式:全局唯一性在软件设计中的艺术实践
java·c++·python·单例模式