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);
    }
}
相关推荐
数模竞赛Paid answer1 小时前
2025年MathorCup数学建模A题汽车风阻预测解题文档与程序
算法·数学建模·mathorcup
xin_nai1 小时前
LeetCode热题100(Java)(6)矩阵
java·leetcode·矩阵
代码AI弗森6 小时前
一文理清楚“算力申请 / 成本测算 / 并发评估”
java·服务器·数据库
Old Uncle Tom7 小时前
OpenClaw 记忆系统 -- 记忆预加载
java·数据结构·算法·agent
会编程的土豆7 小时前
洛谷题单入门1 顺序结构
数据结构·算法·golang
小小小米粒7 小时前
Collection单列集合、Map(Key - Value)双列集合,多继承实现。
java·开发语言·windows
生信碱移7 小时前
PACells:这个方法可以鉴定疾病/预后相关的重要细胞亚群,作者提供的代码流程可以学习起来了,甚至兼容转录组与 ATAC 两种数据类型!
人工智能·学习·算法·机器学习·数据挖掘·数据分析·r语言
智者知已应修善业7 小时前
【51单片机中的打飞机设计】2023-8-25
c++·经验分享·笔记·算法·51单片机
摇滚侠7 小时前
expdp 查看帮助
java·数据库·oracle
:1218 小时前
java基础
java·开发语言