Floyd,最短路维护,LeetCode 2642. 设计可以求最短路径的图类

目录

一、题目

1、题目描述

2、接口描述

​cpp

python3

3、原题链接

二、解题报告

1、思路分析

2、复杂度

3、代码详解

​cpp

python3


一、题目

1、题目描述

给你一个有 n 个节点的 有向带权 图,节点编号为 0n - 1 。图中的初始边用数组 edges 表示,其中 edges[i] = [fromi, toi, edgeCosti] 表示从 fromitoi 有一条代价为 edgeCosti 的边。

请你实现一个 Graph 类:

  • Graph(int n, int[][] edges) 初始化图有 n 个节点,并输入初始边。
  • addEdge(int[] edge) 向边集中添加一条边,其中edge = [from, to, edgeCost] 。数据保证添加这条边之前对应的两个节点之间没有有向边。
  • int shortestPath(int node1, int node2) 返回从节点 node1node2 的路径最小 代价。如果路径不存在,返回 -1 。一条路径的代价是路径中所有边代价之和。

2、接口描述

​cpp
cpp 复制代码
class Graph {
public:
    Graph(int n, vector<vector<int>>& edges) {

    }
    
    void addEdge(vector<int> edge) {

    }
    
    int shortestPath(int node1, int node2) {

    }
};

/**
 * Your Graph object will be instantiated and called as such:
 * Graph* obj = new Graph(n, edges);
 * obj->addEdge(edge);
 * int param_2 = obj->shortestPath(node1,node2);
 */
python3
cpp 复制代码
class Graph:

    def __init__(self, n: int, edges: List[List[int]]):


    def addEdge(self, edge: List[int]) -> None:


    def shortestPath(self, node1: int, node2: int) -> int:



# Your Graph object will be instantiated and called as such:
# obj = Graph(n, edges)
# obj.addEdge(edge)
# param_2 = obj.shortestPath(node1,node2)

3、原题链接

2642. 设计可以求最短路径的图类 - 力扣(LeetCode)


二、解题报告

1、思路分析

数据规模100个点,可以用floyd

我们初始化就直接floyd即可

然后考虑floyd的原理无非就是枚举路径上的点进行动态规划,那么我们对<x, y>这条边进行修改后,以<x, y>这条边进行一次松弛操作即可

2、复杂度

时间复杂度:初始化:O(n^3) ,最短路维护:O(n^2),最短路获取:O(1)空间复杂度:O(n^2)

3、代码详解

​cpp
cpp 复制代码
int g[105][105];
const int inf = 0x3f3f3f3f;
class Graph {
public:
int _n;
    Graph(int n, vector<vector<int>>& edges):_n(n) {
        memset(g, 0x3f, sizeof g);
        for(int i = 0; i < n; i++) g[i][i] = 0;
        for(auto& e : edges)
            g[e[0]][e[1]] = e[2];
        for(int k = 0; k < n; k++)
            for(int i = 0; i < n; i++){
                if(g[i][k] == inf) continue;
                for(int j = 0; j < n; j++)
                    g[i][j] = min(g[i][j], g[i][k] + g[k][j]);
            }
    }
    
    void addEdge(vector<int> e) {
        if(e[2] >= g[e[0]][e[1]]) return;
        int a = e[0], b = e[1];
        g[a][b] = e[2];
        for(int i = 0; i < _n; i++)
            for(int j = 0; j < _n; j++)
                g[i][j] = min(g[i][j], g[i][a] + g[b][j] + e[2]);
    }
    
    int shortestPath(int x, int y) {
        return g[x][y] < inf ? g[x][y] : -1;
    }
};

/**
 * Your Graph object will be instantiated and called as such:
 * Graph* obj = new Graph(n, edges);
 * obj->addEdge(edge);
 * int param_2 = obj->shortestPath(node1,node2);
 */
python3
python 复制代码
class Graph:

    def __init__(self, n: int, edges: List[List[int]]):
        self.g = [[inf] * n for _ in range(n)]
        g = self.g
        for i in range(n):
            g[i][i] = 0
        for x, y, w in edges:
            g[x][y] = w
        for k in range(n):
            for i in range(n):
                for j in range(n):
                    g[i][j] = min(g[i][j], g[i][k] + g[k][j])

    def addEdge(self, edge: List[int]) -> None:
        x, y, w = edge
        g = self.g
        if w > g[x][y]:
            return
        g[x][y] = w
        n = len(self.g)
        for i in range(n):
            for j in range(n):
                g[i][j] = min(g[i][j], g[i][x] + g[y][j] + g[x][y])

    def shortestPath(self, x: int, y: int) -> int:
        g = self.g
        return g[x][y] if g[x][y] < inf else -1



# Your Graph object will be instantiated and called as such:
# obj = Graph(n, edges)
# obj.addEdge(edge)
# param_2 = obj.shortestPath(node1,node2)
相关推荐
88号技师1 小时前
2024年12月一区SCI-加权平均优化算法Weighted average algorithm-附Matlab免费代码
人工智能·算法·matlab·优化算法
IT猿手1 小时前
多目标应用(一):多目标麋鹿优化算法(MOEHO)求解10个工程应用,提供完整MATLAB代码
开发语言·人工智能·算法·机器学习·matlab
88号技师1 小时前
几款性能优秀的差分进化算法DE(SaDE、JADE,SHADE,LSHADE、LSHADE_SPACMA、LSHADE_EpSin)-附Matlab免费代码
开发语言·人工智能·算法·matlab·优化算法
一只小bit1 小时前
数据结构之栈,队列,树
c语言·开发语言·数据结构·c++
我要学编程(ಥ_ಥ)2 小时前
一文详解“二叉树中的深搜“在算法中的应用
java·数据结构·算法·leetcode·深度优先
埃菲尔铁塔_CV算法2 小时前
FTT变换Matlab代码解释及应用场景
算法
沐泽Mu2 小时前
嵌入式学习-QT-Day05
开发语言·c++·qt·学习
许野平2 小时前
Rust: enum 和 i32 的区别和互换
python·算法·rust·enum·i32
chenziang12 小时前
leetcode hot100 合并区间
算法
chenziang12 小时前
leetcode hot100 对称二叉树
算法·leetcode·职场和发展