prim算法

刚学习prim算法,看了好久,最后还是抄了一遍理解清楚了,现在梳理一下框架

53. 寻宝(第七期模拟笔试) (kamacoder.com)

第一步输入数据,没有路径的地方需要设置成一个大数,类似此路不通的意思。用一个grid二维数组记录下来。

第二步记录每个节点到已生成最小生成树的距离,用一个midDir一维数据记录,初始值每个节点都不连通,设为一个大数;然后用一个isAddTree来记录是否已经加入最小生成树。

然后开始prim三部曲,循环遍历v次,因为要加入v个节点(此时的i无任何意义,只代表循环次数):

定义min:记录节点到最小生成树的最小距离.初始设为MAX_VALUE,因为第一个节点要加入

定义当前节点curnode:初始值设为-1

循环每个节点:

1、if(当前节点没有加入生成树&&比已经记录其他节点到生成树的距离都要小):

curnode等于它;

min等于它到最小生成树的距离;

2、遍历完后,找到了最小结点,把它加入到最小生成树,isAddTree = true

3、更新当前结点到最小生成树的距离

遍历每个结点:

if(结点没加入最小生成树&&grid[curnode][j] < midDir):

minDir[j] = grid[curnode][j];

遍历minDir求和得到结果

java 复制代码
import java.util.*;

public class prim{
    public static void main (String[] args) {
        /* code */
        Scanner sc = new Scanner(System.in);
        int v = sc.nextInt();
        int e = sc.nextInt();
        //c从1号节点开始,更符合习惯
        int[][] grid = new int[v+1][v+1];
        for(int i = 0; i<= v; i++){
            Arrays.fill(grid[i],10001);
        }
        for(int i = 0; i < e; i++){
            int s = sc.nextInt();
            int t = sc.nextInt();
            int q = sc.nextInt();
            grid[s][t] = q;
            grid[t][s] = q;
        }

        //存储每个节点到最小生成树的距离
        int[] minDir = new int[v+1];
        Arrays.fill(minDir,10001);

        //记录哪些节点已经加入生成树
        boolean[] isAddTree= new boolean[v+1];

        for(int i = 1; i <= v; i++){
            //1.选择距离生成树最近的节点
            int min = Integer.MAX_VALUE;
            int curNode = -1;
            for(int j = 1; j <= v; j++){
                //如果j结点没有加入并且距离最小,记录当前距离,看看是不是最近的,是最近的就加入
                if(!isAddTree[j] && minDir[j] < min){
                    curNode = j;
                    min = minDir[j];

                }
            }

            //2.将最近的节点加入到最小生成树
            isAddTree[curNode] = true;

            //3.更新节点到最小生成树的距离,因为最小生成树已经更新了(实际只需要更新和curNode的最小距离)
            for(int j = 1; j<=v; j++){
                if(!isAddTree[j] && grid[curNode][j] < minDir[j]){
                    minDir[j] = grid[curNode][j];
                    //System.out.println(minDir[j]);
                }
            }
        }

        //统计结果
        int res = 0;
        for(int i = 2; i <=v; i++){
            res += minDir[i];
        }
        System.out.println(res);
        
        
        
        
        
        /*/打印邻接矩阵
        for(int i = 0; i<v+1;i++){
            for(int j = 0; j<v+1; j++){
                System.out.print(grid[i][j]+" ");
            }
            System.out.println();
        }
        //*/
    }
}
相关推荐
再__努力1点6 分钟前
【76】Haar特征的Adaboost级联人脸检测全解析及python实现
开发语言·图像处理·人工智能·python·算法·计算机视觉·人脸检测
溟洵6 分钟前
【算法C++】链表(题目列表:两数相加、两两交换链表中的节点、重排链表、合并 K 个升序链表、K 个一组翻转链表7)
数据结构·c++·算法·链表
_OP_CHEN6 分钟前
【C++数据结构进阶】玩转并查集:从原理到实战,C++ 实现与高频面试题全解析
数据结构·c++·算法
gugugu.7 分钟前
算法:hot100---128. 最长连续序列
算法
天呐草莓12 分钟前
支持向量机(SVM)
人工智能·python·算法·机器学习·支持向量机·数据挖掘·数据分析
zore_c24 分钟前
【数据结构】队列——超详解!!!(包含队列的实现)
c语言·网络·数据结构·c++·笔记·算法·链表
小杰帅气26 分钟前
智能指针喵喵喵
开发语言·c++·算法
智驱力人工智能35 分钟前
守护生命的水上之眼 无人机人员落水检测系统的技术攻坚与应用实践 无人机溺水识别 山区水库无人机落水检测系统 水域安全无人机部署指南
大数据·人工智能·算法·安全·无人机·边缘计算
hweiyu0037 分钟前
排序算法选型决策树
算法·排序算法
蓝色汪洋3 小时前
xtu oj矩阵
算法