码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • Python有向图从起点到终点遍历所有路径


    参考文章:https://blog.csdn.net/weixin_39797176/article/details/121776940
    在这里插入图片描述

    输入数据说明:

    • graph[1] = [2, 3] 表示顶点1有边指向顶点2和3,将所有的边录入
    • start(1,8)表示遍历从顶点1到顶点8的所有路径
    graph = {}
    allpaths = []
    solopath = []
    
    graph[1] = [2, 3]
    graph[2] = [4, 5]
    graph[3] = [4, 5]
    graph[4] = [5, 6,7]
    graph[5] = [6, 7]
    graph[6] = [7, 8]
    graph[7] = [8]
    
    def dfs(target):
        if target in graph:
            for neighbor in graph[target]:
                if solopath not in allpaths:
                    allpaths.append(solopath[:])
                if neighbor not in solopath:
                    solopath.append(neighbor)
                if solopath not in allpaths:
                    allpaths.append(solopath[:])
                dfs(neighbor)
                solopath.pop()
    def start(start,end):
        solopath.append(start)
        dfs(start)
        allpaths.sort(key=lambda x: len(x), reverse=False)
        i = 1
        for all in allpaths:
            if all[0] == start and all[-1] == end:
                print(i, ' --> ', all)
                i += 1
    start(1,8)
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33

    输出样例:

    1 --> [1, 2, 4, 6, 8]
    2 --> [1, 2, 4, 7, 8]
    3 --> [1, 2, 5, 6, 8]
    4 --> [1, 2, 5, 7, 8]
    5 --> [1, 3, 4, 6, 8]
    6 --> [1, 3, 4, 7, 8]
    7 --> [1, 3, 5, 6, 8]
    8 --> [1, 3, 5, 7, 8]
    9 --> [1, 2, 4, 5, 6, 8]
    10 --> [1, 2, 4, 5, 7, 8]
    11 --> [1, 2, 4, 6, 7, 8]
    12 --> [1, 2, 5, 6, 7, 8]
    13 --> [1, 3, 4, 5, 6, 8]
    14 --> [1, 3, 4, 5, 7, 8]
    15 --> [1, 3, 4, 6, 7, 8]
    16 --> [1, 3, 5, 6, 7, 8]
    17 --> [1, 2, 4, 5, 6, 7, 8]
    18 --> [1, 3, 4, 5, 6, 7, 8]

  • 相关阅读:
    Pandas 2.2 中文官方教程和指南(二十二)
    如何计算 R 中的 Phi 系数
    go 地址 生成唯一索引 --chatGPT
    web3 前端dapp从redux过滤出 (我创建与别人创建)正在执行的订单 并展示在Table上
    22-9-17学习笔记
    LVS+Haproxy
    微信公众号调用接口显示的错误码含义
    【数模/评价模型】Topsis优劣解距离法
    【线性代数基础进阶】特征值和特征向量-补充+练习
    c++ 批量导出c# 函数,格式
  • 原文地址:https://blog.csdn.net/TMaskBoy/article/details/132810119
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号