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

图论入门编程

卡码网刷题链接:98. 所有可达路径

一、题目简述

二、编程demo

方法①邻接矩阵

from collections import defaultdict
#简历邻接矩阵
def build_graph(): n, m = map(int,input().split()) graph = [[0 for _ in range(n+1)] for _ in range(n+1)]for _ in range(m): i,j = map(int,input().split()) graph[i][j] = 1return graph,n
#深度优先搜索
def dfs(g,r,i,end,path):if i == end:r.append(path.copy())return for k in range(1,end+1):if g[i][k]:path.append(k)dfs(g,r,k,end,path)path.pop()return 
#主函数
def main():graph,n = build_graph()result = []path = [1]dfs(graph,result,1,n,path)#按格式打印输出if not result:print(-1)for p in result:print(" ".join(map(str,p)))return 
if __name__ == "__main__":main()

方法②邻接表

from collections import defaultdict
def build_graph(): n, m = map(int,input().split()) graph = defaultdict(list) for _ in range(m): i,j = map(int,input().split()) graph[i].append(j)return graph,ndef dfs(g,r,i,end,path):if i == end:r.append(path.copy())return for k in g[i]:path.append(k)dfs(g,r,k,end,path)path.pop()return def main():graph,n = build_graph()result = []path = [1]dfs(graph,result,1,n,path)if not result:print(-1)for p in result:print(" ".join(map(str,p)))return 
if __name__ == "__main__":main()

http://www.lryc.cn/news/494342.html

相关文章:

  • 在Java中使用Apache POI导入导出Excel(三)
  • UR开始打中国牌,重磅发布国产化协作机器人UR7e 和 UR12e
  • FRU文件
  • AI需求条目化全面升级!支持多格式需求,打破模板限制!
  • Java—I/O流
  • Huginn服务部署
  • 深入解析Java数据包装类型:特性、机制与最佳实践
  • 【Java基础入门篇】二、控制语句和递归算法
  • PostgreSQL WAL日志膨胀处理
  • 用户该怎么管理维护自己的服务器?
  • 【MYSQL数据库相关知识介绍】
  • 初窥 HTTP 缓存
  • yolov8的深度学习环境安装(cuda12.4、ubuntu22.04)
  • RSA算法和AES算法,哪种更安全
  • Vue教程|搭建vue项目|Vue-CLI新版脚手架
  • kdump调试分析(适用于麒麟,ubuntu等OS)
  • houdini肌肉刷pin点的方法
  • JMeter 并发策略-针对准点秒杀场景的压测实现
  • 龙迅#LT6912适用于HDMI2.0转HDMI+LVDS/MIPI,分辨率高达4K60HZ,支持音频和HDCP2.2
  • RBF神经网络预测结合NSGAII多目标优化
  • 如何看linux系统内核是aarch64 ,还是64-bit
  • 如何通过 ADB 安装 xapk
  • QT:多ui界面显示
  • redis cluster 3主3从部署方案
  • 前端学习笔记之文件下载(1.0)
  • 从技术视角看AI在Facebook全球化中的作用
  • Web 表单开发全解析:从基础到高级掌握 HTML 表单设计
  • Milvus 2.5:全文检索上线,标量过滤提速,易用性再突破!
  • 【webrtc】 mediasoup中m77的IntervalBudget及其在AlrDetector的应用
  • AI数据分析工具(二)