当前位置: 首页 > article >正文

代码随想录算法训练营第五十五天|图论理论基础

98. 所有可达路径

卡码网题目链接(ACM模式)(opens new window)

题目描述

给定一个有 n 个节点的有向无环图,节点编号从 1 到 n。请编写一个函数,找出并返回所有从节点 1 到节点 n 的路径。每条路径应以节点编号的列表形式表示。

输入描述

第一行包含两个整数 N,M,表示图中拥有 N 个节点,M 条边

后续 M 行,每行包含两个整数 s 和 t,表示图中的 s 节点与 t 节点中有一条路径

输出描述

输出所有的可达路径,路径中所有节点的后面跟一个空格,每条路径独占一行,存在多条路径,路径输出的顺序可任意。

如果不存在任何一条路径,则输出 -1。

注意输出的序列中,最后一个节点后面没有空格! 例如正确的答案是 1 3 5,而不是 1 3 5, 5后面没有空格!

输入示例

5 5
1 3
3 5
1 2
2 4
4 5
输出示例

1 3 5
1 2 4 5

邻接矩阵写法

def dfs(graph, x, n, path, result):
    if x == n:
        result.append(path.copy())
        return
    for i in range(1, n + 1):
        if graph[x][i] == 1:
            path.append(i)
            dfs(graph, i, n, path, result)
            path.pop()

def main():
    n, m = map(int, input().split())
    graph = [[0] * (n + 1) for _ in range(n + 1)]

    for _ in range(m):
        s, t = map(int, input().split())
        graph[s][t] = 1

    result = []
    dfs(graph, 1, n, [1], result)

    if not result:
        print(-1)
    else:
        for path in result:
            print(' '.join(map(str, path)))

if __name__ == "__main__":
    main()

邻接表写法

from collections import defaultdict

result = []  # 收集符合条件的路径
path = []  # 1节点到终点的路径

def dfs(graph, x, n):
    if x == n:  # 找到符合条件的一条路径
        result.append(path.copy())
        return
    for i in graph[x]:  # 找到 x指向的节点
        path.append(i)  # 遍历到的节点加入到路径中来
        dfs(graph, i, n)  # 进入下一层递归
        path.pop()  # 回溯,撤销本节点

def main():
    n, m = map(int, input().split())

    graph = defaultdict(list)  # 邻接表
    for _ in range(m):
        s, t = map(int, input().split())
        graph[s].append(t)

    path.append(1)  # 无论什么路径已经是从1节点出发
    dfs(graph, 1, n)  # 开始遍历

    # 输出结果
    if not result:
        print(-1)
    for pa in result:
        print(' '.join(map(str, pa)))

if __name__ == "__main__":
    main()

http://www.kler.cn/a/384600.html

相关文章:

  • 2024.11.03 周报
  • MySQL表转移数据的三种方式
  • 千问70B的模型,我要使用V100*8的GPU机器可以做微调吗?
  • RC高通滤波器Bode图分析(传递函数零极点)
  • Linux(CentOS)运行 jar 包
  • 使用代理时Stable Diffusion无法正常下载各类模型的解决办法
  • 从零开始了解数采(十二)——汽车锂电池板自动装配线数据采集方案
  • 离散无记忆信道
  • 鸿蒙生态的崛起
  • C++:红黑树
  • SpringMVC学习记录(二)之接收数据
  • 【JS】字符串方法速览
  • Android——网络请求
  • 大模型落地场景及价值思考
  • ubuntu 20.04 安装使用 nvidia gdrcopy
  • 使用Matlab神经网络工具箱
  • 智能化运维的未来:AI和机器学习在运维中的应用
  • 内网学习一:windows基础
  • Python进程管理:创建和协调多进程的深入指南
  • 远翔升压恒流芯片FP7209X与FP7209M什么区别?做以下应用市场摄影补光灯、便携灯、智能家居(调光)市场、太阳能、车灯、洗墙灯、舞台灯必看!
  • Hive 操作基础(进阶篇☝️)
  • Spring框架之单例模式 (Singleton Pattern)
  • Java对象、类、接口——针对实习面试
  • 探索Python视频处理的瑞士军刀:ffmpeg-python库
  • 在JS中, 0 == [0] 吗
  • 5g通信系统用到的crc码