Java基于Dijkstra算法实现校园导游程序


Posted in Java/Android onMarch 17, 2022

本文实例为大家分享了Dijkstra算法实现校园导游程序的具体代码,供大家参考,具体内容如下

应用设计性实验

1.问题描述

校网导游程序: 一个校园有若干景点,如正校门、人工湖、磁悬浮列车实验室、樱花大道、图书馆、体育场体育馆和礼堂等。实现一个为来访客 人提供信息在询服务的程序,如查询景点的详细信息,查询两个景点之间的一条最短路径。

2.实验要求

(1)设计你所在学校的校园平面图,所含景点不少于10个。
(2)来访客人可以输人任一个景点的名称,查询景点的详细信息。
(3)来访客人可以输人任何两个景点的名称,查询这两个景点之间的一条最短路径。

3.实现提示

以图中的顶点表示校园内各景点,存放景点代号、名称和简介等信息;以边表示路径,存放路径长度等相关信息,如实验图10.2所示。本题可采用邻接方阵或邻接表实现图的存储结构,利用迪杰斯特拉算法求得最短路径。

Java基于Dijkstra算法实现校园导游程序

该程序“见错就收”、“见好就收”效率比较高——“剪枝”。

import java.util.ArrayList;
import java.util.Scanner;
 
public class TourGuide {
    private static final Site[] sites = new Site[14];//以地点代号循序存放地点
    private static final ArrayList<String> arrSites = new ArrayList<>();
    private static final double[][] matrix = new double[14][14];//用来存放地点间的路径长度(对角线为0,不存在为INFINITY)
 
    static {
        sites[0] = new Site(0, "正校门", "正校门...");//初始化存放地点的数组
        sites[1] = new Site(1, "东校门", "东校门...");
        sites[2] = new Site(2, "西校门", "西校门...");
        sites[3] = new Site(3, "北校门", "北校门...");
        sites[4] = new Site(4, "食堂", "食堂...");
        sites[5] = new Site(5, "磁悬浮列车实验室", "磁悬浮列车实验室...");
        sites[6] = new Site(6, "樱花大道", "樱花大道...");
        sites[7] = new Site(7, "图书馆", "图书馆...");
        sites[8] = new Site(8, "体育场", "体育场...");
        sites[9] = new Site(9, "体育馆", "体育馆...");
        sites[10] = new Site(10, "游泳馆", "游泳馆...");
        sites[11] = new Site(6, "礼堂", "礼堂...");
        sites[12] = new Site(6, "教学楼", "教学楼...");
        sites[13] = new Site(6, "宿舍", "宿舍...");
        matrix[0][4] = 35;//初始化地点间的路径长度
        matrix[0][11] = 5;
        matrix[1][10] = 75;
        matrix[1][13] = 10;
        matrix[2][4] = 30;
        matrix[2][7] = 5;
        matrix[3][6] = 15;
        matrix[3][7] = 50;
        matrix[3][9] = 15;
        matrix[3][10] = 20;
        matrix[4][8] = 60;
        matrix[4][11] = 40;
        matrix[5][8] = 45;
        matrix[5][11] = 10;
        matrix[8][11] = 50;
        matrix[9][10] = 20;
        matrix[9][13] = 100;
        matrix[11][12] = 25;
        matrix[12][13] = 20;
 
        for (Site site : sites) arrSites.add(site.getName()); //初始化ArrayList,用于以字符串的形式按顺序存放地点的名字
 
        for (int i = 0; i < sites.length; i++) {//初始化地点间的路径长度
            for (int j = 0; j < sites.length; j++) {
                if (i != j && matrix[i][j] == 0)
                    matrix[i][j] = Double.POSITIVE_INFINITY;
                if (i > j)
                    matrix[i][j] = matrix[j][i];
            }
        }
    }
 
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        int select;
        while (true) {
            System.out.println("请输入您想了解的信息:\n1.查询地点详细信息\n2.查询地点间的最短路径\n3.退出系统");
            select = scanner.nextInt();
            switch (select) {
                case 1:
                    System.out.print("输入查询地点的名称: ");
                    String siteIntro = query(scanner.next());
                    if (siteIntro != null) {//其实这里也可以直接arrSites.indexOf(name)判断
                        System.out.println(siteIntro);
                    } else {
                        System.err.println("输入的地点名称不存在!");
                    }
                    break;
                case 2:
                    System.out.print("输入所要查询最短路径的两地的名称(例如:正校门-礼堂): ");
                    String path = findShortestPath(scanner.next());
                    if (path != null) {
                        System.out.println(path);
                    } else {
                        System.err.println("输入的所要查询最短路径的两地的名称或者格式有误!");
                    }
                    break;
                case 3:
                    System.exit(0);
                default:
                    System.err.println("输入的选项有误!");
            }
            System.out.println();
        }
    }
 
    public static String query(String siteName) {
        int index = arrSites.indexOf(siteName);
        if (index == -1) {
            return null;
        } else {
            return sites[index].getIntro();
        }
    }
 
    public static String findShortestPath(String path) {
        int indexOfSeparator = path.indexOf('-');
        if (indexOfSeparator == -1) return null;
        String start = path.substring(0, indexOfSeparator);
        String end = path.substring(indexOfSeparator + 1);
        int indexOfStart = arrSites.indexOf(start);
        int indexOfEnd = arrSites.indexOf(end);
        if (indexOfStart == -1 || indexOfEnd == -1) return null;
        return dijkstra(indexOfStart, indexOfEnd);
    }
 
    private static String dijkstra(int start, int end) {
        int vertexCount = TourGuide.matrix.length;
        boolean[] isInUSet = new boolean[vertexCount];//数组元素默认初始化为false
        double[] distant = new double[vertexCount];
        int[] parent = new int[vertexCount];
        for (int i = 0; i < vertexCount; i++) {
            distant[i] = TourGuide.matrix[start][i];
            parent[i] = start;
        }
        isInUSet[start] = true;
        distant[start] = 0;
        parent[start] = -1;
 
        for (int i = 0; i < vertexCount; i++) {
            double minCost = Double.POSITIVE_INFINITY;
            int minIndex = start;
            for (int j = 0; j < vertexCount; j++) {
                if (!isInUSet[j])
                    if (distant[j] < minCost) {
                        minCost = distant[j];
                        minIndex = j;
                    }
            }
            if (minCost < Double.POSITIVE_INFINITY) {
                isInUSet[minIndex] = true;
            } else {
                break;      //处理的图为非连通图,即不输出相应路径(不存在能达到该顶点的路径)
            }
            if (minIndex == end)//找到后直接return提高效率
                return printDijkstra(parent, distant, start, end);
            for (int j = 0; j < vertexCount; j++) {//迭代优化
                if (!isInUSet[j] && distant[minIndex] + TourGuide.matrix[minIndex][j] < distant[j]) {
                    distant[j] = distant[minIndex] + TourGuide.matrix[minIndex][j];
                    parent[j] = minIndex;
                }
            }
        }
        return null;
    }
 
    private static String printDijkstra(int[] parent, double[] distant, int start, int end) {
        int p = parent[end];
        StringBuilder path = new StringBuilder(arrSites.get(end));
        while (p != -1) {
            path.insert(0, arrSites.get(p) + "->");
            p = parent[p];
        }
        return arrSites.get(start) + "->" + arrSites.get(end) + " [" + path + "]: " + distant[end];
    }
}
 
class Site {
    private int code;
    private String name;
    private String intro;
 
    public Site(int code, String name, String intro) {
        this.code = code;
        this.name = name;
        this.intro = intro;
    }
 
    public int getCode() {
        return code;
    }
 
    public void setCode(int code) {
        this.code = code;
    }
 
    public String getName() {
        return name;
    }
 
    public void setName(String name) {
        this.name = name;
    }
 
    public String getIntro() {
        return intro;
    }
 
    public void setIntro(String intro) {
        this.intro = intro;
    }
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Java/Android 相关文章推荐
Java新手教程之ArrayList的基本使用
Jun 20 Java/Android
小程序与后端Java接口交互实现HelloWorld入门
Jul 09 Java/Android
SpringBoot快速入门详解
Jul 21 Java/Android
Java spring单点登录系统
Sep 04 Java/Android
Java 实战项目之家居购物商城系统详解流程
Nov 11 Java/Android
Java 深入探究讲解简单工厂模式
Apr 07 Java/Android
Java后端 Dubbo retries 超时重试机制的解决方案
Apr 14 Java/Android
Jmerte 分布式压测及分布式压测配置
Apr 30 Java/Android
java开发双人五子棋游戏
May 06 Java/Android
springcloud整合seata
May 20 Java/Android
Spring IOC容器Bean的作用域及生命周期实例
May 30 Java/Android
springboot实现string转json json里面带数组
Jun 16 Java/Android
Java中的随机数Random
Mar 17 #Java/Android
SpringBoot中HttpSessionListener的简单使用方式
Mar 17 #Java/Android
SpringBoot+Redis实现布隆过滤器的示例代码
Mar 17 #Java/Android
Java9新特性对HTTP2协议支持与非阻塞HTTP API
Java练习之潜艇小游戏的实现
Mar 16 #Java/Android
你知道Java Spring的两种事务吗
Java并发编程之原子性-Atomic的使用
You might like
rephactor 优秀的PHP的重构工具
2011/06/09 PHP
php文件怎么打开 如何执行php文件
2011/12/21 PHP
PHP输出一个等腰三角形的方法
2015/05/12 PHP
PHP+Javascript实现在线拍照功能实例
2015/07/18 PHP
php 升级到 5.3+ 后出现的一些错误,如 ereg(); ereg_replace(); 函数报错
2015/12/07 PHP
joomla实现注册用户添加新字段的方法
2016/05/05 PHP
利用javascript数组长度循环数组内所有元素
2013/12/27 Javascript
jquery+html5烂漫爱心表白动画代码分享
2015/08/24 Javascript
JQuery EasyUI的使用
2016/02/24 Javascript
Node.js的npm包管理器基础使用教程
2016/05/26 Javascript
Bootstrap3使用typeahead插件实现自动补全功能
2016/07/07 Javascript
微信小程序 绘图之饼图实现
2016/10/24 Javascript
深入理解vue.js中$watch的oldvalue与newValue
2017/08/07 Javascript
js实现1,2,3,5数字按照概率生成
2017/09/12 Javascript
Validform验证时可以为空否则按照指定格式验证
2017/10/20 Javascript
基于JavaScript实现报警器提示音效果
2017/10/27 Javascript
浅谈React Event实现原理
2018/09/20 Javascript
详解vue移动端项目代码拆分记录
2019/03/15 Javascript
ES6入门教程之let、const的使用方法
2019/04/13 Javascript
vue项目中极验验证的使用代码示例
2019/12/03 Javascript
[05:17]DOTA2睡衣妹卖萌求签名 CJ第二天全明星影像
2013/07/28 DOTA
[01:18:21]EG vs TNC Supermajor小组赛B组败者组第一轮 BO3 第一场 6.2
2018/06/03 DOTA
Python搭建HTTP服务器和FTP服务器
2017/03/09 Python
用Python编写一个高效的端口扫描器的方法
2018/12/20 Python
python自动点赞功能的实现思路
2020/02/26 Python
python使用pymongo与MongoDB基本交互操作示例
2020/04/09 Python
python支持多继承吗
2020/06/19 Python
html5 Canvas画图教程(5)—canvas里画曲线之arc方法
2013/01/09 HTML / CSS
布鲁明戴尔百货店:Bloomingdale’s
2016/12/21 全球购物
廉政教育心得体会
2014/01/01 职场文书
临床护士自荐信
2014/01/31 职场文书
煤矿安全生产责任书
2014/04/15 职场文书
2016年元旦主持词
2015/07/06 职场文书
关于五一放假的通知
2015/08/18 职场文书
小学语文教师研修感悟
2015/11/18 职场文书
大学生团支书竞选稿
2015/11/21 职场文书