【代码随想录算法训练营——Day60】图论——94.城市间货物运输I、95.城市间货物运输II、96.城市间货物运输III

卡码网题目链接

https://kamacoder.com/problempage.php?pid=1152

https://kamacoder.com/problempage.php?pid=1153

https://kamacoder.com/problempage.php?pid=1154

题解
94.城市间货物运输I

和昨天那题思路类似,加了个队列优化,仿照着c++代码写的。

95.城市间货物运输II

具体看题解,代码也是仿照题解写的。

96.城市间货物运输III

看题解的感悟:理解思路挺重要,还有了4个拓展,联系了前几天的算法。

代码部分:要加updated更新记录,防止时间超限,题解也是这么写的

代码

python 复制代码
#94.城市间货物运输I
from collections import deque
class Edge():
    def __init__(self, to, val):
        self.to = to
        self.val = val

if __name__ == "__main__":
    n, m = map(int, input().split())
    graph = [[] for _ in range(n + 1)]
    isInQueue = [False] * (n + 1)
    for _ in range(m):
        s, t, v = map(int, input().split())
        graph[s].append(Edge(t, v))
    start = 1
    end = n
    minDist = [float('inf')] * (n + 1)
    minDist[start] = 0
    queue = deque()
    queue.append(start)
    isInQueue[start] = True
    while queue:
        node = queue.popleft()
        isInQueue[node] = False
        for edge in graph[node]:
            fromm, to, val = node, edge.to, edge.val
            if minDist[to] > minDist[fromm] + val:
                minDist[to] = minDist[fromm] + val
                if isInQueue[to] == False:
                    queue.append(to)
                    isInQueue[to] = True
    if minDist[end] == float('inf'):
        print("unconnected")
    else:
        print(minDist[end])
python 复制代码
#95.城市间货物运输II
if __name__ == "__main__":
    n, m = map(int, input().split())
    graph = []
    for _ in range(m):
        graph.append(list(map(int, input().split())))
    minDist = [float('inf')] * (n + 1)
    start, end = 1, n
    minDist[start] = 0
    flag = False
    for i in range(1, n + 1): # 多循环一次
        for side in graph:
            fromm, to, val = side[0], side[1], side[2]
            if i < n:
                if minDist[fromm] != float('inf') and minDist[to] > minDist[fromm] + val:
                    minDist[to] = minDist[fromm] + val
            else:
                if minDist[fromm] != float('inf') and minDist[to] > minDist[fromm] + val:
                    flag = True
    if flag:
        print("circle")
    elif minDist[end] == float('inf'):
        print("unconnected")
    else:
        print(minDist[end])
python 复制代码
#96.城市间货物运输III
if __name__ == "__main__":
    n, m = map(int, input().split())
    graph = []
    for _ in range(m):
        graph.append(list(map(int, input().split())))
    src, dst, k = map(int, input().split())
    minDist = [float('inf')] * (n + 1)
    minDist[src] = 0
    for i in range(k + 1):
        updated = False
        minDist_copy = minDist.copy()
        for side in graph:
            fromm, to, val = side[0], side[1], side[2]
            if minDist_copy[fromm] != float('inf') and minDist[to] > minDist_copy[fromm] + val:
                minDist[to] = minDist_copy[fromm] + val
                updated = True
        if not updated:
            break
    if minDist[dst] == float('inf'):
        print("unreachable")
    else:
        print(minDist[dst])
相关推荐
Polaris北极星少女11 分钟前
TRSV优化2
算法
代码游侠1 小时前
C语言核心概念复习——网络协议与TCP/IP
linux·运维·服务器·网络·算法
2301_763472461 小时前
C++20概念(Concepts)入门指南
开发语言·c++·算法
Libraeking1 小时前
视觉篇:Canvas 自定义绘图与高级动画的华丽圆舞曲
android·经验分享·android jetpack
abluckyboy2 小时前
Java 实现求 n 的 n^n 次方的最后一位数字
java·python·算法
Fushize2 小时前
多模块架构下的依赖治理:如何避免 Gradle 依赖地狱
android·架构·kotlin
园小异2 小时前
2026年技术面试完全指南:从算法到系统设计的实战突破
算法·面试·职场和发展
m0_706653232 小时前
分布式系统安全通信
开发语言·c++·算法
Jomurphys3 小时前
Kotlin - 类型别名 typealias
android·kotlin
Haha_bj3 小时前
Flutter ——flutter_screenutil 屏幕适配
android·ios