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

Day 55 卡玛笔记

这是基于代码随想录的每日打卡

所有可达路径

题目描述

​ 给定一个有 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
提示信息

img

用例解释:

​ 有五个节点,其中的从 1 到达 5 的路径有两个,分别是 1 -> 3 -> 5 和 1 -> 2 -> 4 -> 5。

​ 因为拥有多条路径,所以输出结果为:

​ 1 3 5 1 2 4 5或1 2 4 5 1 3 5 都算正确。

数据范围:

  • ​ 图中不存在自环
  • ​ 图中不存在平行边
  • ​ 1 <= N <= 100
  • ​ 1 <= M <= 500

邻接矩阵法

def dfs(matrices,path,res,node,n):
    if node==n:
        res.append(path[:])
        return
    
    for i in range(1,n+1):  # 每层有n个叶子节点
        if matrices[node][i]==1:
            path.append(i)
            dfs(matrices,path,res,i,n)
            path.pop()  # 回溯

def main():
    n,m=map(int,input().split())
    # 创建邻接矩阵
    matrices=[[0 for _ in range(n+1)] for _ in range(n+1)]
    for _ in range(m):
        start,end=map(int,input().split())
        matrices[start][end]=1
    res=[]
    dfs(matrices,[1],res,1,n)
    if len(res)==0:
        print(-1)
    else:
        for path in res:
            print(' '.join(map(str,path)))
    
if __name__=='__main__':
    main()

运行结果

在这里插入图片描述


邻接表法

from collections import defaultdict
def dfs(graph,res,path,node,n):
    if node==n:
        res.append(path[:])
        return 
    
    for i in graph[node]:  # 遍历每层叶子节点
        path.append(i)
        dfs(graph,res,path,i,n)
        path.pop()  # 回溯
    
def main():
    n,m=map(int,input().split())
    # 创建邻接表
    graph=defaultdict(list)
    for _ in range(m):
        start,end=map(int,input().split())
        graph[start].append(end)
    res=[]
    dfs(graph,res,[1],1,n)
    if not res:
        print(-1)
    else:
        for path in res:
            print(' '.join(map(str,path)))
    
if __name__=='__main__':
    main()

运行结果

在这里插入图片描述



797. 所有可能的路径

给你一个有 n 个节点的 有向无环图(DAG),请你找出所有从节点 0 到节点 n-1 的路径并输出(不要求按特定顺序

graph[i] 是一个从节点 i 可以访问的所有节点的列表(即从节点 i 到节点 graph[i][j]存在一条有向边)。

示例 1:

img

输入:graph = [[1,2],[3],[3],[]]
输出:[[0,1,3],[0,2,3]]
解释:有两条路径 0 -> 1 -> 3 和 0 -> 2 -> 3

示例 2:

img

输入:graph = [[4,3,1],[3,2,4],[3],[4],[]]
输出:[[0,4],[0,3,4],[0,1,3,4],[0,1,2,3,4],[0,1,4]]

class Solution:
    def __init__(self):
        self.path=[]
        self.res=[]

    def dfs(self,graph,node,n):
        if node==n-1:
            self.res.append(self.path[:])
            return 

        for node in graph[node]:
            self.path.append(node)
            self.dfs(graph,node,n)
            self.path.pop()
            
    def allPathsSourceTarget(self, graph: List[List[int]]) -> List[List[int]]:
        self.path.append(0)
        self.dfs(graph, 0, len(graph))
        return self.res 

运行结果

在这里插入图片描述

相关文章:

  • 华为 VRP 系统简介配置SSH,TELNET远程登录
  • SqlSugar 语法糖推荐方式
  • 【弹框组件封装】展示、打印、下载XX表(Base64格式图片)
  • win11编译pytorchvision cuda128版本流程
  • C++中读取与保存不同维度的csv数据
  • 计算机毕业设计SpringBoot+Vue.js图书馆管理系统(源码+文档+PPT+讲解)
  • Red Hat Enterprise Linux 发行日期!
  • 开源ocr
  • 希音(Shein)运维面试题集锦和参考答案
  • aiohttp、httpx 和 requests 的区别
  • Tomcat 8 安装包下载
  • Leetcode 206 -反转链表
  • io学习----->标准io
  • 解锁ApplicationContext vs BeanFactory: 谁更具选择性?
  • Mac 下载安装并卸载多jdk教程
  • HTTP/1.1 和 HTTP/2 的区别,HTTP/2 有哪些新特性?
  • Transformer结构和注意力机制
  • 数组中的逆序对(C++)
  • 六十天前端强化训练之第八天之JavaScript核心之ES6变量与箭头函数(第8-14天:JavaScript核心)
  • 【Python运维】 Python与日志管理:构建高效的集中式日志收集与分析系统
  • 篮球培训机构东方启明星被指停摆,家长称已登记未退费用超百万
  • 美国关税压力下,日本经济一年来首次萎缩
  • 一图读懂丨创新创业人才最高补贴500万元!临港新片区发布创客新政“十二条”
  • 选址江南制造总局旧址,上海工业博物馆建设有新进展
  • 从能源装备向应急装备蓝海拓展,川润股份发布智能综合防灾应急仓
  • 李家超:明日起香港特区护照持有人可免签入境阿联酋