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);
    }
}
相关推荐
我爱我家8822 小时前
亚洲艺术电影节携澳门文化亮相深圳
人工智能·物联网·算法·区块链·爬山算法
Aawy1202 小时前
C++中的状态模式高级应用
开发语言·c++·算法
zyq99101_12 小时前
蓝桥杯刷题算法实战解析
数据结构·python·算法·蓝桥杯
sali-tec2 小时前
C# 基于OpenCv的视觉工作流-章39-FL特征匹配
图像处理·人工智能·opencv·算法·计算机视觉
穗余2 小时前
java大模型应用开发里的SseEmitter和websocket区别
java·开发语言·人工智能·websocket
好家伙VCC2 小时前
# 发散创新:用 Rust构建高并发虚拟世界引擎核心模块在当今游戏开发与元宇宙构建中,**虚拟世界的性能瓶颈往往不是图形渲染,而是底
java·开发语言·python·rust·图形渲染
Liu628882 小时前
C++中的状态模式
开发语言·c++·算法
smchaopiao2 小时前
使用C语言打印几何图形:从三角形到菱形
c语言·开发语言·算法
爱滑雪的码农2 小时前
Java基础六:条件语句与switch case
java·开发语言