【数据结构课程设计报告】路径规划系统(Java实现)

本文主要是介绍【数据结构课程设计报告】路径规划系统(Java实现),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

数据结构课程设计报告


路径规划系统

  • 数据结构课程设计报告
  • 一、需求分析
  • 二、系统功能划分及设计
    • 1.存储结构设计
    • 2.系统的功能架构设计
    • 3.模块设计
    • 3.代码实现


一、需求分析

问题描述:路径规划系统的业务活动包括:路径信息的添加、以邻接矩阵方式显示路径信息、最短路径的两种规划方式(1.Dijkstra 2.Floyd)等,需对指定内容进行分析设计利用计算机加以实现。

路径所涉及的信息有:顶点数即地点数、边数即路径数、所有顶点信息、每条路径的两个端点信息和每条路径的权值。

系统能够实现的功能与操作如下:
1.添加路径信息:根据用户依次输入的内容(顶点数、边数、顶点信息、每条路径的两个端点信息和权值),对所需添加的路径进行相应存储。
2.查看邻接矩阵:根据用户输入的路径信息绘制以权值为主的相应邻接矩阵。
3.规划方式:根据用户选择的规划方式(1.Dijkstra 2.Floyd)若选择1,待用户输入需要查询的顶点下标后使用Dijkstra算法,计算输入顶点与其他顶点之间的最短路径并显示;若选择2,待用户输入需要查询的两个端点信息后使用Floyd算法,计算两个端点之间的最短路径并显示。
4.退出系统:退出当前界面。

输出界面:有主菜单、分菜单可对上述所说2的内容进行用户的相应选择和呈现,以达到系统的交互性。
编译环境:win10;eclipse;
所使用的编译语言:Java语言

二、系统功能划分及设计

1.存储结构设计

有向图的邻接矩阵存储结构示意图

系统存储结构设计采用有向图的邻接矩阵存储结构。运用两个数组,一个是一维数组存储图中顶点信息,另一个是二维数组即矩阵,存储顶点之间边的信息。

2.系统的功能架构设计

系统功能流程图

系统功能架构流程设计如图所示,主函数调用菜单函数进行菜单选择(1-4)。

  1. 当用户选择1时,调用添加路径信息,待用户依次输入顶点数,边数,顶点信息,每条路径的两个端点信息和权值,如输入信息类型格式无误则可添加成功。
  2. 当用户选择2时,调用查询邻接矩阵,如此时未添加路径信息,需添加路径信息才可查看相应邻接矩阵。
  3. 当用户选择3时,调用规划方式菜单选择(1-3),1代表以Dijkstra算法为主的最短路径查询,2代表以Floyd算法为主的最短路径查询, 3返回主菜单。
  4. 退出系统。

3.模块设计

路径规划系统各类属性方法关系图

如上图所示为系统所涉及到各类的属性、方法及各类之间的关系图。

3.代码实现

public class Graph<T> {protected final int MAXSIZE = 20; // 邻接矩阵可以表示的最大顶点数protected final int MAX = 9999; // 在网中,表示没有联系(权值无穷大)protected T[] V;// 顶点信息protected int[][] arcs;// 邻接矩阵protected int e;// 边数protected int n;// 顶点数protected boolean[] visited; // 访问标志数组static String elementAll;// 用户输入的顶点元素public Graph() {V = (T[]) new Object[MAXSIZE];arcs = new int[MAXSIZE][MAXSIZE];visited = new boolean[MAXSIZE];}// 1:在图中查找顶点v,找到后返回其在顶点数组中的索引号// 若不存在,返回-1public int LocateVex(T v) {int i;for (i = 0; i < n; i++)if (V[i] == v)return i;return -1;}// 2:在屏幕上显示图G的邻接矩阵表示public void DisplayAdjMatrix() {int i, j;for (i = 0; i < n; i++) {for (j = 0; j < n; j++) {System.out.print(arcs[i][j] + "\t");}System.out.println();}}// 3:创建有向图的邻接矩阵public void CreateAdj() {int i, j, k;T v1, v2;Scanner sc = new Scanner(System.in);System.out.print("请输入图的顶点数:n=");if (sc.hasNextInt()) {n = sc.nextInt();System.out.print("请输入图的边数:e=");if (sc.hasNextInt()) {e = sc.nextInt();System.out.print("请输入图的顶点信息:");String str = sc.next();elementAll = str;if (str.toCharArray().length == n) {for (i = 0; i < n; i++)V[i] = (T) (Object) str.charAt(i);// 构造顶点信息for (i = 0; i < n; i++)for (j = 0; j < n; j++)arcs[i][j] = MAX;// 初始化for (k = 0; k < e; k++) {// 建立有向网的邻接矩阵int w;System.out.print

这篇关于【数据结构课程设计报告】路径规划系统(Java实现)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Java 正则表达式URL 匹配与源码全解析

《Java正则表达式URL匹配与源码全解析》在Web应用开发中,我们经常需要对URL进行格式验证,今天我们结合Java的Pattern和Matcher类,深入理解正则表达式在实际应用中... 目录1.正则表达式分解:2. 添加域名匹配 (2)3. 添加路径和查询参数匹配 (3) 4. 最终优化版本5.设计思

C#实现将Excel表格转换为图片(JPG/ PNG)

《C#实现将Excel表格转换为图片(JPG/PNG)》Excel表格可能会因为不同设备或字体缺失等问题,导致格式错乱或数据显示异常,转换为图片后,能确保数据的排版等保持一致,下面我们看看如何使用C... 目录通过C# 转换Excel工作表到图片通过C# 转换指定单元格区域到图片知识扩展C# 将 Excel

Java使用ANTLR4对Lua脚本语法校验详解

《Java使用ANTLR4对Lua脚本语法校验详解》ANTLR是一个强大的解析器生成器,用于读取、处理、执行或翻译结构化文本或二进制文件,下面就跟随小编一起看看Java如何使用ANTLR4对Lua脚本... 目录什么是ANTLR?第一个例子ANTLR4 的工作流程Lua脚本语法校验准备一个Lua Gramm

Java字符串操作技巧之语法、示例与应用场景分析

《Java字符串操作技巧之语法、示例与应用场景分析》在Java算法题和日常开发中,字符串处理是必备的核心技能,本文全面梳理Java中字符串的常用操作语法,结合代码示例、应用场景和避坑指南,可快速掌握字... 目录引言1. 基础操作1.1 创建字符串1.2 获取长度1.3 访问字符2. 字符串处理2.1 子字

Java Optional的使用技巧与最佳实践

《JavaOptional的使用技巧与最佳实践》在Java中,Optional是用于优雅处理null的容器类,其核心目标是显式提醒开发者处理空值场景,避免NullPointerExce... 目录一、Optional 的核心用途二、使用技巧与最佳实践三、常见误区与反模式四、替代方案与扩展五、总结在 Java

基于Java实现回调监听工具类

《基于Java实现回调监听工具类》这篇文章主要为大家详细介绍了如何基于Java实现一个回调监听工具类,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录监听接口类 Listenable实际用法打印结果首先,会用到 函数式接口 Consumer, 通过这个可以解耦回调方法,下面先写一个

使用Java将DOCX文档解析为Markdown文档的代码实现

《使用Java将DOCX文档解析为Markdown文档的代码实现》在现代文档处理中,Markdown(MD)因其简洁的语法和良好的可读性,逐渐成为开发者、技术写作者和内容创作者的首选格式,然而,许多文... 目录引言1. 工具和库介绍2. 安装依赖库3. 使用Apache POI解析DOCX文档4. 将解析

Qt中QGroupBox控件的实现

《Qt中QGroupBox控件的实现》QGroupBox是Qt框架中一个非常有用的控件,它主要用于组织和管理一组相关的控件,本文主要介绍了Qt中QGroupBox控件的实现,具有一定的参考价值,感兴趣... 目录引言一、基本属性二、常用方法2.1 构造函数 2.2 设置标题2.3 设置复选框模式2.4 是否

Java字符串处理全解析(String、StringBuilder与StringBuffer)

《Java字符串处理全解析(String、StringBuilder与StringBuffer)》:本文主要介绍Java字符串处理全解析(String、StringBuilder与StringBu... 目录Java字符串处理全解析:String、StringBuilder与StringBuffer一、St

C++使用printf语句实现进制转换的示例代码

《C++使用printf语句实现进制转换的示例代码》在C语言中,printf函数可以直接实现部分进制转换功能,通过格式说明符(formatspecifier)快速输出不同进制的数值,下面给大家分享C+... 目录一、printf 原生支持的进制转换1. 十进制、八进制、十六进制转换2. 显示进制前缀3. 指