day 55 图论part7

文章目录

  • [prim算法精讲 卡码网 53. 寻宝(第七期模拟笔试)](#prim算法精讲 卡码网 53. 寻宝(第七期模拟笔试))
  • [kruskal算法精讲 53. 寻宝(第七期模拟笔试)](#kruskal算法精讲 53. 寻宝(第七期模拟笔试))

prim算法精讲 卡码网 53. 寻宝(第七期模拟笔试)

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

class Main {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);

        int V = sc.nextInt();
        int E = sc.nextInt();
        int[][] grid = new int[V + 1][V + 1];
        for (int i = 0 ; i <= V; i++) {
            Arrays.fill(grid[i], Integer.MAX_VALUE);
        }

        for (int i = 0; i < E; i++) {
            int s = sc.nextInt();
            int t = sc.nextInt();
            grid[s][t] = sc.nextInt();
            grid[t][s] = grid[s][t];
        }

        int[] minDist  = new int[V + 1];
        Arrays.fill(minDist, Integer.MAX_VALUE);
        boolean[] isTree = new boolean[V + 1];
        for (int i = 1; i < V; i++) {
            int minvalue = Integer.MAX_VALUE;
            int cur = 1;
            for (int j = 1; j <= V; j++)  {
                if (!isTree[j] && minDist[j] < minvalue) {
                    minvalue = minDist[j];
                    cur = j;
                }
            }
            isTree[cur] = true;
            for (int j = 1; j <= V; j++) {
                if (isTree[j] == false && grid[cur][j] < minDist[j]) {
                    minDist[j] = grid[cur][j];
                }
            }
        }
        int result = 0;

        for (int i = 2; i <=V; i++) {
            result += minDist[i];
        }
        System.out.println(result);
    }
}

kruskal算法精讲 53. 寻宝(第七期模拟笔试)

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


class Edge {
    int l, r, val;
    public Edge(int l, int r, int val) {
        this.l = l;
        this.r = r;
        this.val = val;
    }
}
class Main {
    
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        int v = sc.nextInt();
        int e = sc.nextInt();
        List<Edge> edges = new ArrayList<>();
        for (int i = 0; i < e; i++) {
            int v1 = sc.nextInt();
            int v2 = sc.nextInt();
            int val = sc.nextInt();
            edges.add(new Edge(v1, v2, val));
        }

        edges.sort(Comparator.comparingInt(edge -> edge.val));
        int res = 0;
        DisJoint disjoint = new DisJoint(v + 1);
        for (Edge edge : edges) {
            int x = disjoint.find(edge.l);
            int y = disjoint.find(edge.r);
            if (x != y) {
                res += edge.val;
                disjoint.join(x, y);
            }
        }
        System.out.println(res);

    }
}

class DisJoint {
    private int[] father;

    public DisJoint(int N) {
        father = new int[N + 1];
        for (int i = 0; i <= N; i++) {
            father[i] = i;
        }
    }
    public int find(int n) {
        return father[n] == n ? n : (father[n] = find(father[n]));
    }

    public void join(int n, int m) {
        n = find(n);
        m = find(m);
        if (n == m) {
            return;
        }
        father[n] = m;
    }

    public boolean isSame(int n, int m) {
        return find(n) == find(m);
    }
}
相关推荐
周末也要写八哥1 分钟前
线程的生命周期之线程睡眠
java·开发语言·jvm
炸薯条!7 分钟前
二叉树的链式表示(2)
java·数据结构·算法
Tairitsu_H10 分钟前
[LC优选算法#2] 滑动窗口 | 长度最小的子数组 | 无重复字符的最长子串 | 最大连续1的个数
算法
小欣加油12 分钟前
leetcode3689最大子数组总值I
c++·算法·leetcode·职场和发展·贪心算法
徐寿春19 分钟前
什么是数据倾斜
java·guava
下午写HelloWorld19 分钟前
【概念与应用】轻量级加密算法LEA、动态脱敏算法DDA、零知识证明ZKP和优化协同交互协议OCIP
算法·区块链·密码学·安全架构·零知识证明
李白的天不白27 分钟前
一个服务器可以搭建多个网站
java·tomcat
●VON27 分钟前
AtomGit Flutter鸿蒙客户端:共享组件
java·flutter·华为·harmonyos·鸿蒙
程序猿乐锅28 分钟前
【JAVASE | 第十七篇】Java 网络通信
java·开发语言
执于代码29 分钟前
Java交互打印的问题
java