解题思路:

注意事项:

参考代码:

import java.util.Arrays;
import java.util.Scanner;

/**
 * @Author:杨雨彤
 * @date:2024/1/12 16:25
 */
public class 城市路Dijkstra {

    public static void main(String[] args) {
        Scanner scan=new Scanner(System.in);
        int n= scan.nextInt();
        int m=scan.nextInt();
        int [][]matrix=new int[n][n];
        int max=10000;
        for (int i = 0; i <n ; i++) {
            for (int j = 0; j <n ; j++) {
                matrix[i][j]=max;
            }
        }
        for (int i = 0; i <m ; i++) {
            int a= scan.nextInt();
            int b= scan.nextInt();
            int distance=scan.nextInt();
            if(matrix[a-1][b-1]>distance){
                matrix[a-1][b-1]= distance;
                matrix[b-1][a-1]=distance;
            }
        }
        System.out.println(Dijkstra(0,matrix));
    }
    public static int Dijkstra(int source,int[][]matrix){
        boolean[]visited=new boolean[matrix.length];//状态数组,存储顶点的访问状态
        int[]distance=new int[matrix.length];//存储各顶点距离出发顶点的最短距离
        int[]pre_arr=new int[matrix.length];//记录每个顶点的前驱顶点
        Arrays.fill(pre_arr,-1);//初始化,-1表示无前驱顶点
        for (int i = 0; i < matrix.length; i++) {
            distance[i] = matrix[source][i];//初始化distance,默认当前距离最短
            if(matrix[0][i]<10000) {
                pre_arr[i]=0;//初始化pre_arr表示若连通,则前驱顶点为出发顶点
            }
        }
        visited[source]=true;//出发顶点的访问状态为true
        distance[source]=0;//到自身的最短距离为0
        int len= matrix.length;
        //需要访问剩余得len-1个顶点
        for (int i = source+1; i<len; i++) {
            int mindist = Integer.MAX_VALUE;
            int min = -1;
            //找到距离出发点最近且没被访问过的顶点,记录其距离以及下标
            for (int j = 0; j <len; j++) {
                if (!visited[j] && distance[j] < mindist ) {
                    mindist = distance[j];
                    min = j;
                }
            }
            if (mindist == Integer.MAX_VALUE) {
                break;
            }
            //找到顶点后将其状态置为true,已找到source距离min的最小距离
            visited[min] = true;
            //找到min顶点后,更新与min连通的其他顶点距离source的最小距离数组distance
            for (int j = 0; j <len; j++) {
                //如果该顶点未被访问且source到min的最小距离加上min到该顶点的距离要比source到该顶点的原始距离小
                if (!visited[j] &&distance[min] + matrix[min][j] < distance[j]) {
                    //表示我们找到了该顶点到source顶点的更近距离,故更新distance[j],记录最小距离
                    distance[j] =distance[min] + matrix[min][j];
                    //同时将该顶点的前驱顶点设置为min,表示该顶点是通过min顶点才找到一条距source更近的路的
                    pre_arr[j] = min;
                }
            }
        }
         //返回最后一个顶点到source的最短距离
            return  distance[len-1];
    }
}


点赞(0)
 

0.0分

1 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论