Acwing 849. Dijkstra求最短路 I

题目

给定一个 n 个点 m 条边的有向图,图中可能存在重边和自环,所有边权均为正值。

请你求出 1 号点到 n 号点的最短距离,如果无法从 1 号点走到 n号点,则输出 −1。

输入格式

第一行包含整数 n 和 m。

接下来 m 行每行包含三个整数 x,y,z表示存在一条从点 x 到点 y 的有向边,边长为 z。

输出格式

输出一个整数,表示 1 号点到 n�号点的最短距离。

如果路径不存在,则输出 −1。

数据范围

1≤n≤500 1≤m≤105 图中涉及边长均不超过10000。

输入样例:

复制代码
3 3
1 2 2
2 3 1
1 3 4

输出样例:

复制代码
3

代码与解析

模板题啦,一定要掌握的

java 复制代码
import java.util.Arrays;
import java.util.Scanner;

public class Main {
    static int n, m, N = 10010;
    static int[] dis = new int[510];
    static int[][] g = new int[510][510];
    static boolean[] state = new boolean[510];  // 记录节点状态,true表示已确定最短路径

    public static void main(String[] args) {
        Scanner in = new Scanner(System.in);
        n = in.nextInt();
        m = in.nextInt();

        // 初始化邻接矩阵,初始值为 N 表示无穷大
        for (int i = 1; i <= n; i++) {
            Arrays.fill(g[i], N);
        }

        // 输入图的边信息,记录最小的边权值
        for (int i = 0; i < m; i++) {
            int x = in.nextInt();
            int y = in.nextInt();
            int z = in.nextInt();
            g[x][y] = Math.min(g[x][y], z);
        }

        System.out.println(dijkstra());
    }

    public static int dijkstra() {
        Arrays.fill(dis, N); // 初始化距离数组,初始值为 N 表示无穷大
        dis[1] = 0; // 起点到自身距离为0

        // 循环进行n次,每次找到一个离起点最近的节点,更新其相邻节点的距离
        for (int i = 1; i < n; i++) {
            int t = -1; // t 存储当前访问的节点

            // 找到未确定最短路径的节点中距离起点最近的节点
            for (int j = 1; j <= n; j++) {
                if (!state[j] && (t == -1 || dis[t] > dis[j])) {
                    t = j;
                }
            }

            state[t] = true; // 将该节点标记为已确定最短路径

            // 更新相邻节点的距离
            for (int j = 1; j <= n; j++) {
                dis[j] = Math.min(dis[j], dis[t] + g[t][j]);
            }
        }

        return dis[n] == N ? -1 : dis[n]; // 如果终点距离为无穷大,说明不可达,返回-1,否则返回最短距离
    }
}
  1. 输入: 从输入中获取节点数 n、边数 m 以及图的边信息。

  2. 初始化: 初始化邻接矩阵 g 和距离数组 dis,将所有距离初始值设置为无穷大 N,状态数组 state 用于记录节点的最短路径是否已确定。

  3. 构建图: 遍历输入的边信息,记录每条边的最小权值。

  4. Dijkstra 算法: 使用 Dijkstra 算法求解最短路径。

    • 从起点开始,每次选择未确定最短路径的节点中距离起点最近的节点,标记该节点为已确定最短路径。
    • 更新该节点的相邻节点的距离,取最小值。
    • 重复以上步骤,直到所有节点的最短路径都被确定。
  5. 输出结果: 输出终点到起点的最短距离,若不可达则输出 -1

相关推荐
LaughingDangZi8 分钟前
vue+java分离项目实现微信公众号开发全流程梳理
java·前端·后端
神奇小汤圆11 分钟前
RabbitMQ发布订阅模式同一消费者多个实例如何防止重复消费?
后端
leeggco17 分钟前
Batfish Dashboard 项目说明文档
后端
qq_124987075341 分钟前
基于springboot健康养老APP的设计与实现(源码+论文+部署+安装)
java·spring boot·后端·mysql·微信小程序·毕业设计
盒马盒马1 小时前
Rust:内部可变性 & 型变
开发语言·后端·rust
无限大61 小时前
为什么玩游戏需要独立显卡?——GPU与CPU的分工协作
后端·程序员
Moment1 小时前
小米不仅造车,还造模型?309B参数全开源,深度思考完胜DeepSeek 🐒🐒🐒
前端·人工智能·后端
马卡巴卡1 小时前
SpringBoot集成Spring Statemachine(状态机)实战教程
后端
酒酿萝卜皮2 小时前
Elastic Search 安装使用
后端
kkk_皮蛋2 小时前
信令是什么?为什么 WebRTC 需要信令?
后端·asp.net·webrtc