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]);
        }

    }
}
相关推荐
码云数智-大飞5 分钟前
分布式锁的“双雄对决”:Redis 与 ZooKeeper 的深度博弈与选型指南
算法
cpp_250112 分钟前
P1910 L 国的战斗之间谍
数据结构·c++·算法·题解·洛谷·背包dp
txzrxz14 分钟前
c++深度搜索讲解及例题
开发语言·c++·深度搜索·例题讲解
yu859395814 分钟前
时延估计的互相关算法(MATLAB实现)
开发语言·算法·matlab
m0_6779048415 分钟前
K8s学习
java·学习·kubernetes
ou.cs16 分钟前
c# SemaphoreSlim保姆级教程
开发语言·网络·c#
逸风尊者17 分钟前
2026 主流 Claw 类产品技术报告
人工智能·后端·算法
|_⊙17 分钟前
红黑树 (C++)
开发语言·c++·学习
楼田莉子19 分钟前
同步/异步日志系统:工具类以及日志的简单模块
linux·服务器·数据结构·c++
强盛机器学习~21 分钟前
考虑异常天气和太阳辐射下基于强化学习的无人机三维路径规划
算法·matlab·无人机·强化学习·路径规划·无人机路径规划·q-learning