Dijkstra最短路径(Java)(详细+模板)

简介: Dijkstra最短路径(Java)(详细+模板)

思路:

首先使用数组存储,从起点开始找距离起点最近的点t,然后以t为中间点修正从起点到未访问各点的距离,以上操作执行n次。

代码:

package text2;

import java.util.*;
import java.io.*;
public class Dijkstra {
  static int n,m;
  static int g[][] = new int[10005][10005];//存放图
//  static int dis[] = new int[n];//起点到每个点的最短距离
  static int vis[] = new int[10005];//是否被标记过
  
  public static void main(String[] args) {
    // TODO Auto-generated method stub
    Scanner scanner = new Scanner(System.in);
    n = scanner.nextInt();//顶点数
    m = scanner.nextInt();//边数
    int s = scanner.nextInt();//图的起点
//    Arrays.fill(dis, 0x3f3f3f3f);
    for (int i = 0; i < n; i++) {
      Arrays.fill(g[i], 0x3f3f3f3f);
      g[i][i]=0;
    }
    Arrays.fill(vis, 0);
    for(int i=0;i<m;i++) {
      int v1=scanner.nextInt();
      int v2=scanner.nextInt();
      int weight=scanner.nextInt();
      g[v1][v2]=weight;
      g[v2][v1]= weight; 
    }
    dijkstra(0);
    System.out.print(g[0][2]);
  }
  //固定模板
  public static void dijkstra(int s) {
    for(int i=0;i<n;i++) {
      int t=-1;
      int min = 0x3f3f3f3f;
      //找距离起点最近的一个点t(而且未被访问过)
      for(int j=0;j<n;j++) {
        if(vis[j]==0&&(t==-1||g[s][j]<min)) {
          min = g[s][j];
          t = j;
        }
      }
      vis[t] = 1;
      //以u为中间点,修正从【起点s】到未访问各点的距离 
      for(int j=0;j<n;j++) {
        if(vis[j]==0) {
          if(g[s][t]+g[t][j]<g[s][j]) {
            g[s][j] = g[s][t]+g[t][j];
            //此处还可以加路径
          }
        }
      }
    }
  }
}

相关文章
|
3月前
|
存储 人工智能 算法
数据结构与算法细节篇之最短路径问题:Dijkstra和Floyd算法详细描述,java语言实现。
这篇文章详细介绍了Dijkstra和Floyd算法,这两种算法分别用于解决单源和多源最短路径问题,并且提供了Java语言的实现代码。
106 3
数据结构与算法细节篇之最短路径问题:Dijkstra和Floyd算法详细描述,java语言实现。
|
3月前
|
搜索推荐 Java 数据库连接
Java|在 IDEA 里自动生成 MyBatis 模板代码
基于 MyBatis 开发的项目,新增数据库表以后,总是需要编写对应的 Entity、Mapper 和 Service 等等 Class 的代码,这些都是重复的工作,我们可以想一些办法来自动生成这些代码。
45 6
|
3月前
|
算法 Java Linux
java制作海报四:java BufferedImage 转 InputStream 上传至OSS。png 图片合成到模板(另一个图片)上时,透明部分变成了黑色
这篇文章主要介绍了如何将Java中的BufferedImage对象转换为InputStream以上传至OSS,并解决了png图片合成时透明部分变黑的问题。
138 1
|
3月前
|
Java
Java PDF模板生成PDF
Java PDF模板生成PDF
68 1
|
3月前
|
小程序
java--微信小程序发送模板消息
java--微信小程序发送模板消息
165 0
|
5月前
|
小程序 Java
【aspose-words】Aspose.Words for Java模板语法详细剖析
本文通过详细分析Aspose.Words for Java模板语法,介绍了使用条件块、变量和动态合并表格单元格三个常用模板标签,并结合实际案例进行演示。通过这三个标签的实操,帮助读者更好地掌握Aspose.Words的使用技巧。此外,还提供了官方文档链接以便进一步学习。
175 0
【aspose-words】Aspose.Words for Java模板语法详细剖析
|
5月前
|
Java
Java系列之 IDEA 为类 和 方法设置注解模板
这篇文章介绍了如何在IntelliJ IDEA中为类和方法设置注解模板,包括类模板的创建和应用,以及两种不同的方法注解模板的创建过程和实际效果展示,旨在提高代码的可读性和维护性。
|
4月前
|
Java Apache Maven
Java中使用poi+poi-tl实现根据模板导出word文档
这个过程不仅简化了文档生成的工作,而且保证了生成文档的一致性与准确性,特别适合于那些需要生成大量文档的自动化场景。通过以上步骤,Java开发人员可以实现高效、可靠的Word文档导出功能。
1734 0
|
6月前
|
算法 Java
Java语言实现最短路径算法(Shortest Path)
Java语言实现最短路径算法(Shortest Path)
77 3
|
6月前
|
存储 Java 应用服务中间件
Java中套路和实现问题之基于组合/模板的套路常见框架中的应用有什么
Java中套路和实现问题之基于组合/模板的套路常见框架中的应用有什么
下一篇
开通oss服务