【代码随想录算法训练营——Day58】图论——117.软件构建、47. 参加科学大会

卡码网题目链接

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

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

题解
117.软件构建

(拓扑排序)

代码是完全照着题解的代码写的.

47.参加科学大会

(最短路)

代码

python 复制代码
#117.软件构建
from collections import defaultdict, deque
if __name__ == "__main__":
    n, m = map(int, input().split())
    inDegree = [0] * n
    umap = defaultdict(list)
    result = []
    for _ in range(m):
        s, t = map(int, input().split())
        inDegree[t] += 1
        umap[s].append(t)
    queue = deque()
    for i in range(n):
        if inDegree[i] == 0:
            queue.append(i)
    while queue:
        cur = queue.popleft()
        result.append(cur)
        files = umap[cur]
        for j in files:
            inDegree[j] -= 1
            if(inDegree[j] == 0):
                queue.append(j)
    if len(result) == n:
        for i in range(n - 1):
            print(f"{result[i]} ", end = "")
        print(result[n - 1])
    else:
        print(-1)
python 复制代码
#47.参加科学大会
if __name__ == "__main__":
    n, m = map(int, input().split())
    graph = [[float('inf')] * (n + 1) for _ in range(n + 1)]
    for i in range(m):
        s, e, v = map(int, input().split())
        graph[s][e] = v
    minDist = [float('inf')] * (n + 1)
    visited = [False] * (n + 1)
    start = 1
    end = n
    minDist[start] = 0
    for i in range(1, n + 1):
        minVal = float('inf')
        cur = 1
        for j in range(1, n + 1):
            if visited[j] == False and minDist[j] < minVal:
                minVal = minDist[j]
                cur = j
        visited[cur] = True
        for j in range(1, n + 1):
            if visited[j] == False and graph[cur][j] != float('inf') and minDist[cur] + graph[cur][j] < minDist[j]:
                minDist[j] = minDist[cur] + graph[cur][j]
    if minDist[end] == float('inf'):
        print(-1)
    else:
        print(minDist[end])
相关推荐
50万马克的面包4 分钟前
C语言第3讲:分支和循环
c语言·开发语言·笔记·算法
码农小韩10 分钟前
QT学习记录(三)——C++学习基础(三)
开发语言·c++·qt·学习·算法·嵌入式软件
承渊政道13 分钟前
【动态规划算法】(似包非包以及卡特兰数问题深入解析)
数据结构·c++·学习·算法·leetcode·动态规划·哈希算法
fangzt201022 分钟前
从零搭建自动驾驶中间件(四):数据录制与回灌——算法调试的核心基础设施
算法·中间件·自动驾驶
搬砖的小码农_Sky30 分钟前
比特币区块链:SHA256哈希函数
算法·区块链·哈希算法
承渊政道39 分钟前
【动态规划算法】(一文讲透二维费用的背包问题)
数据结构·c++·学习·算法·leetcode·动态规划·哈希算法
Zevalin爱灰灰7 小时前
现代密码学 第二章——流密码【下】
算法·密码学
飞Link9 小时前
大模型长文本的“救命稻草”:深度解析 TurboQuant 与 KV Cache 压缩技术
算法
郝学胜-神的一滴10 小时前
深度学习优化核心:梯度下降与网络训练全解析
数据结构·人工智能·python·深度学习·算法·机器学习
Je1lyfish10 小时前
CMU15-445 (2025 Fall/2026 Spring) Project#3 - QueryExecution
linux·c语言·开发语言·数据结构·数据库·c++·算法