Leetcode 刷题笔记1 图论part01

图论的基础知识:

图的种类: 有向图(边有方向) 、 无向图(边无方向)、加权有向图(边有方向和权值)

度: 无向图中几条边连接该节点,该节点就有几度;有向图中每个节点有入度和出度

**连通性:**在无向图中,任何两个节点都是可以到达的,称之为连通图,否则称之为非连通图

在有向图中,热河两个节点是可以相互到达的,称之为强连通图

联通分量: 在无向图中的极大连通子图称之为该图的一个连通分量

强连通分量: 有向图中极大强连通子图称之为强连通分量

**图的构造:**一般使用邻接表、邻接矩阵和朴素存储

**图的遍历方式:**深度优先搜索(dfs)、广度优先搜索(bfs)

卡码网 98 所有可达路径

python 复制代码
import sys
from collections import defaultdict

path = []
result = []

def main():
    n, m = map(int, input().split())
    graph = defaultdict(list)
    for _ in range(m):
        x, t = map(int, input().split())
        graph[x].append(t)
    path.append(1)
    dfs(graph, 1, n)
    if not result:
        print(-1)
    for pa in result:
        print(' '.join(map(str, pa)))

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

if __name__ == '__main__':
    main()
相关推荐
超级大只老咪2 小时前
快速进制转换
笔记·算法
TracyCoder1233 小时前
LeetCode Hot100(19/100)——206. 反转链表
算法·leetcode
踩坑记录3 小时前
leetcode hot100 94. 二叉树的中序遍历 easy 递归 dfs
leetcode
Fᴏʀ ʏ꯭ᴏ꯭ᴜ꯭.4 小时前
Keepalived VIP迁移邮件告警配置指南
运维·服务器·笔记
ling___xi5 小时前
《计算机网络》计网3小时期末速成课各版本教程都可用谢稀仁湖科大版都可用_哔哩哔哩_bilibili(笔记)
网络·笔记·计算机网络
醉颜凉5 小时前
【LeetCode】打家劫舍III
c语言·算法·leetcode·树 深度优先搜索·动态规划 二叉树
达文汐6 小时前
【困难】力扣算法题解析LeetCode332:重新安排行程
java·数据结构·经验分享·算法·leetcode·力扣
一匹电信狗6 小时前
【LeetCode_21】合并两个有序链表
c语言·开发语言·数据结构·c++·算法·leetcode·stl
User_芊芊君子6 小时前
【LeetCode经典题解】搞定二叉树最近公共祖先:递归法+栈存路径法,附代码实现
算法·leetcode·职场和发展
培风图南以星河揽胜6 小时前
Java版LeetCode热题100之零钱兑换:动态规划经典问题深度解析
java·leetcode·动态规划