day 57 图论part9

文章目录

  • [dijkstra(堆优化版)精讲 47. 参加科学大会(第六期模拟笔试)](#dijkstra(堆优化版)精讲 47. 参加科学大会(第六期模拟笔试))
  • [Bellman_ford 算法精讲 94. 城市间货物运输 I](#Bellman_ford 算法精讲 94. 城市间货物运输 I)

dijkstra(堆优化版)精讲 47. 参加科学大会(第六期模拟笔试)

加入小顶堆,每次从优先队列获取到最小值,不需要遍历整个数组。

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


class Edge {
    int to;
    int val;
    Edge(int to, int val) {
        this.to = to;
        this.val = val;
    }
}

class Pair {
    public int first;
    public int second;
    Pair(int first, int second) {
        this.first = first;
        this.second = second;
    }
}

class MyComparision implements Comparator<Pair> {
    @Override
    public int compare(Pair r, Pair l) {
        return Integer.compare(r.second, l.second);
    }
}


class Main {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        int n = sc.nextInt();
        int m = sc.nextInt();
        int[] minDist = new int[n + 1];
        List<List<Edge>> grid = new ArrayList<>(n + 1);
        Arrays.fill(minDist, Integer.MAX_VALUE);
        for (int i =0; i <= n; i++) {
            grid.add(new ArrayList<>());
        }
        for (int i = 0; i < m; i++) {
            int s = sc.nextInt();
            int t = sc.nextInt();
            int val = sc.nextInt();
            grid.get(s).add(new Edge(t, val));
        }
        boolean[] visited  = new boolean[n + 1];
        PriorityQueue<Pair> pq = new PriorityQueue<>(new MyComparision());
        pq.add(new Pair(1, 0));
        minDist[1] = 0;

        while (!pq.isEmpty()) {
            Pair cur = pq.poll();
            visited[cur.first] = true;
            for (Edge edge : grid.get(cur.first)) {
                if (!visited[edge.to] && minDist[edge.to] > minDist[cur.first] + edge.val) {
                    minDist[edge.to] = minDist[cur.first] + edge.val;
                    pq.add(new Pair(edge.to, minDist[edge.to]));
                }
            }
        }
        if (minDist[n] == Integer.MAX_VALUE) {
            System.out.println(-1);
        }
        else {
            System.out.println(minDist[n]);
        }
    }
}

Bellman_ford 算法精讲 94. 城市间货物运输 I

总共最多需要松弛边n - 1次,得到每一个点到原点的最短距离。

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


class Edge {
    int from;
    int to;
    int val;
    Edge(int from, int to, int val) {
        this.from = from;
        this.to = to;
        this.val = val;
    }
}
class Main {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        int n = sc.nextInt();
        int m = sc.nextInt();
        List<Edge> edges = new ArrayList<>();
        
        for (int i = 0; i < m; i++) {
            int s = sc.nextInt();
            int t = sc.nextInt();
            int v = sc.nextInt();
            edges.add(new Edge(s, t, v));
        }
        int[] minDist = new int[n + 1];
        Arrays.fill(minDist, Integer.MAX_VALUE);
        minDist[1] = 0;

        for (int i = 1; i < n; i++) {
            for (Edge edge : edges) {
                if (minDist[edge.from] != Integer.MAX_VALUE && minDist[edge.from] + edge.val < minDist[edge.to]) {
                    minDist[edge.to] = minDist[edge.from] + edge.val;
                }
            }
        }
        if (minDist[n] == Integer.MAX_VALUE) {
            System.out.println("unconnected");
        }
        else {
            System.out.println(minDist[n]);
        }

    }
}
相关推荐
Ws_1 小时前
C#学习 Day2
开发语言·学习·c#
lcreek1 小时前
Java 反序列化漏洞深度解析(一):从URLDNS到真正的DNS探测
java·反序列化漏洞
杰克尼2 小时前
天机学堂复习总结(day03-day04)
java·开发语言·redis·elasticsearch·spring cloud
x***r1512 小时前
jdk-11.0.16.1_windows使用步骤详解(附JDK 11环境变量配置与验证教程)
java·开发语言·windows
EllinY2 小时前
CF2217E Definitely Larger 题解
c++·笔记·算法·构造
弹简特3 小时前
【Java项目-轻聊】01-项目演示+项目介绍+准备工作+项目源码
java
luck_bor3 小时前
File类&递归作业
java·开发语言
武子康3 小时前
Java-07 深入浅出 MyBatis数据库一对多关系模型实战:表结构设计与查询实现
java·后端
REDcker5 小时前
Linux OverlayFS详解
java·linux·运维