数据结构(12)Dijkstra算法JAVA版:图的最短路径问题

news2024/11/16 21:51:36

目录

12.1.概述

12.1.1.无权图的最短路径

 12.1.2.带权图的最短路径

1.单源最短路径

2.多源最短路径

12.2.代码实现


12.1.概述

12.1.1.无权图的最短路径

无权图的最短路径,即最少步数,使用BFS+贪心算法来求解最短路径,比较好实现,此处不做展开讨论。

 12.1.2.带权图的最短路径

有权图的最短路径,不考虑权重为负数的情况,因为权重为负数的情况极有可能出现负值圈,在这个圈子上形成环路,最短路径是无限兜圈,趋于负无穷。

所以此处我们只考虑权重不为负数的带权图的最短路径求解问题。带权图的最短路径求解问题主要求两种最短路径:

  • 单源最短路径,某个点到全图各点之间的最短路径。
  • 多源最短路径,遍历全图的最短路径。

单源最短路径用Dijkstra算法求解,多源最短路径用Floyd算法求解。

1.单源最短路径

单源最短路径用Dijkstra算法求解,Dijkstra算法其本质是个贪心算法。整个过程就是选择局部最优解,组成最后的解。

以下展示一个Dijkstra求解v1的单源最短路径的过程:

 记录两个值:

distance,到某个结点的最短距离,初始化值为无穷大,表示暂时未记录。

route,全局最短路径,初始化值为-1,表示暂时未记录。

下标1234567
distance无穷大无穷大无穷大无穷大无穷大无穷大无穷大
route-1-1-1-1-1-1-1

 v1开始,刷新distance和route的值:

v1—>v1,distance为0

v1—>v2,distance为2<∞,将2刷新为v1—>v2的最短距离,将1(指代v1)刷新为最短路径。

v4同理……

下标1234567
distance02无穷大1无穷大无穷大无穷大
route-11-11-1-1-1

扫描distance表发现distance最小的v4,于是将v4上得到的数据刷新进distance和route:

下标1234567
distance0231395
route-1141444

一直重复上面步骤,直到图里所有结点都被遍历一次,会得到如下结果:

下标1234567
distance0231365
route-1141474

distance记录的是v1到每个结点的最短路径,route里面记录的最大值是全局遍历一遍的最短路径。

2.多源最短路径

多源最短路径用floyd算法求解,多源最短路径不能只关注于当前最优解,还要关注全局最优解,求解此类问题一般使用动态规划,floyd算法就是个求解多源最短路径的经典动态规划算法。本文主要论述Dijkstra算法,floyd算法暂时不展开。

12.2.代码实现

以遍历如下无向图为例(为什么不遍历上面的例子喃?因为代码是很久前写的了。上面的例子是写文的时候新写的,偷个懒不想改代码了~嘿嘿):

public class Dijkstra {
    static int[][] graph;
    static int[] dist;
    static int[] path=new int[7];
    static boolean[] isUsed=new boolean[7];
    static {
        graph=new int[][]{
                {0,1,4,3,0,0,0},
                {1,0,3,0,0,0,0},
                {4,3,0,2,1,5,0},
                {3,0,2,0,2,0,0},
                {0,0,1,2,0,0,0},
                {0,0,5,0,0,0,2},
                {0,0,0,0,0,2,0}
        };
        dist=new int[]{Integer.MAX_VALUE,Integer.MAX_VALUE,Integer.MAX_VALUE,Integer.MAX_VALUE,Integer.MAX_VALUE,Integer.MAX_VALUE,Integer.MAX_VALUE};
    }
    public static void dijkstra(){
        while(true){
            //判断节点是否已经全部纳入
            if(isOver()){
                break;
            }
            //寻找未纳入的dist最小节点
            int i=findMin();
            //设置为已遍历状态
            isUsed[i]=true;
            //遍历该节点邻接节点
            for (int j=0;j<graph[i].length;j++) {
                if(graph[i][j]!=0&&isUsed[j]==false){
                    //更新dist、path
                    flashDistAndPath(i,j);
                }
            }
        }
    }

    public static int findMin(){
        int min=Integer.MAX_VALUE;
        int index=-1;
        for(int i=0;i<dist.length;i++){
            if(min>dist[i]&&isUsed[i]==false){
                min=dist[i];
                index=i;
            }
        }
        return index;
    }

    //之前的dist值一定是之前该节点到根节点的最短路径开销
    public static void flashDistAndPath(int i,int j){
            if(isUsed[j]==false) {
                if (graph[i][j] + dist[i] < dist[j]) {
                    dist[j] = graph[i][j] + dist[i];
                    path[j] = j;
                }
            }
    }

    public static boolean isOver(){
        int trues=0;
        for (boolean isused:isUsed) {
            if(isused==true){
                trues++;
            }
        }
        if(trues==dist.length){
            return true;
        }
        return false;
    }

    public static void main(String[] args) {
        isUsed[0]=true;
        dist[1]=1;
        dist[2]=4;
        dist[3]=3;

        path[1]=0;
        path[2]=0;
        path[3]=0;
        dijkstra();
        for (int i=0;i<dist.length;i++){
            System.out.println(dist[i]);
        }
    }
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/63745.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

04-05 - 主引导程序的扩展(实验未完)

---- 整理自狄泰软件唐佐林老师课程 1. 突破限制的思路 限制&#xff1a;主引导程序的代码不能超过512字节 主引导程序完成&#xff1a; 完成最基本的初始化工作从存储介质中加载程序到内存将控制权交由新加载的程序执行…… 问题&#xff1a; 主引导程序如何加载存储介质中的…

Windows上Qt源码调试(使用VS2017调试qt5.12.0)

环境&#xff1a;vs2017 qt 5.12.0 msvc32和msvc64 1.下载源代码 把所用 Qt 库版本对应源码&#xff08;qt-everywhere-src-5.12.0&#xff09;下载来解压&#xff08;https://download.qt.io/archive/qt/5.12/5.12.0/single/&#xff09;&#xff0c;或者安装时选择把源码&…

一文带你掌握JSP基础知识

✅作者简介&#xff1a;热爱国学的Java后端开发者&#xff0c;修心和技术同步精进。 &#x1f34e;个人主页&#xff1a;Java Fans的博客 &#x1f34a;个人信条&#xff1a;不迁怒&#xff0c;不贰过。小知识&#xff0c;大智慧。 &#x1f49e;当前专栏&#xff1a;JAVA开发者…

赋能建筑建材企业物流网络内外联通,B2B交易管理系统打造行业智慧供应链

数据显示&#xff0c;在疫情和行业转型升级的双重压力下&#xff0c;行业中竞争力不强、商业模式老套的建筑建材企业在疫情中产值下降甚至被淘汰出局。随着数字经济的兴起&#xff0c;传统建筑建材产业的发展也带来了巨大的变革。 据有关数据分析指出&#xff0c;数字化已经成…

数据之道读书笔记-08打造“清洁数据”的质量综合管理能力

数据之道读书笔记-08打造“清洁数据”的质量综合管理能力 越来越多的企业应用和服务都基于数据而建&#xff0c;数据质量是数据价值得以发挥的前提。例如企业运营效率主要依赖于数据获取的准确性和及时性&#xff0c;企业客户关系管理系统中的错误或不完整数据将导致客户沟通不…

安卓讲课笔记6.1 共享参数

文章目录零、本讲学习目标一、导入新课二、新课讲解&#xff08;一&#xff09;数据存储&#xff08;二&#xff09;共享参数1、共享参数概述2、利用共享参数读写文件步骤&#xff08;三&#xff09;案例演示&#xff1a;多窗口共享数据1、创建安卓应用2、准备图片素材3、主界面…

【LeetCode每日一题】——141.环形链表

文章目录一【题目类别】二【题目难度】三【题目编号】四【题目描述】五【题目示例】六【解题思路】七【题目提示】八【题目进阶】九【时间频度】十【代码实现】十一【提交结果】一【题目类别】 链表 二【题目难度】 简单 三【题目编号】 141.环形链表 四【题目描述】 给…

【gbase8a】docker搭建gbase8a,详细【图文】

docker搭建gbase8a安装docker安装GBase 8a查询安装的版本拉取镜像启动进入容器创建用户dbever测试安装docker 其中具有docker的搭建 搭建docker&#xff0c;docker搭建达梦数据库&#xff0c;详细【图文】 https://blog.csdn.net/weixin_44385419/article/details/127738868 d…

Spark 数据倾斜调优10策

一、数据倾斜概述 1.1 什么是数据倾斜 对Hadoop、Spark、Flink这样的大数据系统来讲&#xff0c;数据量大并不可怕&#xff0c;可怕的是数据倾斜。 何谓数据倾斜&#xff1f;数据倾斜指的是&#xff0c;并行处理的数据集中&#xff0c;某一部分&#xff08;如Spark或Kafka的…

@SpringBootApplication中的注解

Target(ElementType.TYPE)&#xff1a;指示适用注释类型的上下文&#xff08;即注解的作用目标&#xff09;这里是接口、类、枚举、注解 Retention(RetentionPolicy.RUNTIME)&#xff1a;指示具有注释类型的注释要保留多长时间&#xff0c;这里注解是将被JVM保 留,所以在运行…

无法安装64位版本的office,因为在您的PC上找到以下32位程序

无法安装64位版本的office,因为在您的PC上找到以下32位程序: 请卸载所有32位office程序&#xff0c;然后重试安装64位office。如果想要安装32位office&#xff0c;请运行32位安装程序。 那为什么会出现这种情况呢&#xff1f; 首先&#xff0c;我们要知道我们的电脑是32位的还…

9个发展您的B2B业务的LinkedIn营销策略

没有比在 LinkedIn 上与其他公司建立联系更好的地方了。您可以与数以百万计的品牌和专业人士建立联系并发展您的业务。 您可以尝试多种不同的 B2B LinkedIn营销策略&#xff0c;以便与您的受众建立联系并将他们转变为您的客户。 事实上&#xff0c;根据公司自己的研究&#x…

Vue3.2中的setup语法糖(易懂)

简介 在vue3中删除了vue2中的data函数&#xff0c;因此&#xff0c;vue3.0要在template中使用某些变量就必须在最后return出来&#xff0c;多次声明变量&#xff0c;不太方便。而在vue3.2版本之后&#xff0c;新增了setup语法糖。 直接在script标签中添加setup属性就可以直接使…

Arduino开发实例-DIY电能表

DIY电能表 在本文中,将展示如何制作一个基于 Arduino 的功率和电能表。应用使用 INA219 电流传感器测量电流、功率和能耗,并将其显示在 OLED 显示屏上。 可以在 OLED 显示屏上查看您的电压、电流、功率和能量数据。 1、INA219介绍 INA219 电流传感器是一款支持 I2C 的基于…

Unity手机游戏发热发烫优化指南与技巧

Unity手机游戏发热发烫优化指南与技巧 很多小伙伴做完游戏后&#xff0c;发布到Android,运行&#xff0c;游戏很流畅&#xff0c;也不卡顿&#xff0c;但是跑一会游戏,手机就发热,发烫。客户提出需求&#xff0c;能否让它不发烫? 本文从以下3方面来分析手机发烫的问题&#x…

如何用一颗芯片实现5V转正负12V

有时在一些运算放大电路中我们需要同时有正电源和负电源&#xff0c; 但是我们输入一般只有一个正电源&#xff0c;比如我们输入的电源是5V&#xff0c;但是需要将5V转换成正负12V 5V转12V的话我们可以用BOOST电路进行升压&#xff0c;电路图如下 而5V转-12V的话一般有负压电荷…

osgEarth示例分析——osgearth_tracks

前言 osgearth_tracks示例&#xff0c;演示了所有图标沿着路径进行移动(路径是不可见的)。 执行效果 执行命令&#xff1a;osgearth_tracksd.exe earth_image\world.earth 右下角的控制面板功能&#xff1a; Declutter 是否开启 【清理器】 功能。 即当两个图标靠近时&…

HTML期末学生大作业-使用HTML+CSS技术仿传智博客网站

&#x1f389;精彩专栏推荐 &#x1f4ad;文末获取联系 ✍️ 作者简介: 一个热爱把逻辑思维转变为代码的技术博主 &#x1f482; 作者主页: 【主页——&#x1f680;获取更多优质源码】 &#x1f393; web前端期末大作业&#xff1a; 【&#x1f4da;毕设项目精品实战案例 (10…

今日财富杂志今日财富杂志社今日财富编辑部2022年第21期目录

经济纵横 资产证券化税收政策的国际比较与启示 李依莎; 1-3 中小企业知识产权保护的困境 程诗鸿; 4-6 县级政府在优化营商环境中的作用 李晓春; 7-9《今日财富》投稿&#xff1a;cnqikantg126.com 地域文化背景下论房地产经济发展的区域差异 周莹; 10-12 国…

这把联网智能门锁体验感A+

如果来一次古人与今人的谈话&#xff0c;那一定离不开的话题就是“智能设备”。智能手机、智能电脑、智能手表更新换代如此之快&#xff0c;联网智能门锁亦是如此。对于用户而言&#xff0c;使用智能设备最重要的就是“体验感”了&#xff0c;小编为大家强势推荐中科易安QY-170…