【代码随想录算法训练营——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])
相关推荐
qq_41712925几秒前
C++中的桥接模式变体
开发语言·c++·算法
YuTaoShao37 分钟前
【LeetCode 每日一题】3010. 将数组分成最小总代价的子数组 I——(解法二)排序
算法·leetcode·排序算法
松☆1 小时前
Dart 核心语法精讲:从空安全到流程控制(3)
android·java·开发语言
吴维炜2 小时前
「Python算法」计费引擎系统SKILL.md
python·算法·agent·skill.md·vb coding
_李小白3 小时前
【Android 美颜相机】第二十三天:GPUImageDarkenBlendFilter(变暗混合滤镜)
android·数码相机
Σίσυφος19003 小时前
PCL Point-to-Point ICP详解
人工智能·算法
玄〤3 小时前
Java 大数据量输入输出优化方案详解:从 Scanner 到手写快读(含漫画解析)
java·开发语言·笔记·算法
weixin_395448914 小时前
main.c_cursor_0202
前端·网络·算法
senijusene4 小时前
数据结构与算法:队列与树形结构详细总结
开发语言·数据结构·算法
杜家老五4 小时前
综合实力与专业服务深度解析 2026北京网站制作公司六大优选
数据结构·算法·线性回归·启发式算法·模拟退火算法