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

展示型网站设计今日国内新闻

展示型网站设计,今日国内新闻,网络建站的费用,做网站图片太多怎么办这是基于代码随想录的每日打卡 所有可达路径 题目描述 ​ 给定一个有 n 个节点的有向无环图,节点编号从 1 到 n。请编写一个函数,找出并返回所有从节点 1 到节点 n 的路径。每条路径应以节点编号的列表形式表示。 输入描述 ​ 第一行包含两个整数…

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

所有可达路径

题目描述

​ 给定一个有 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[:])returnfor 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]=1res=[]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 

运行结果

在这里插入图片描述

http://www.dtcms.com/wzjs/223272.html

相关文章:

  • 北京建设网站 公司百度怎么注册自己的店铺
  • 医院网站建设方案策划书创建网址链接
  • 公司网站模板凡建站温州高端网站建设
  • limesurvey wordpressaso优化贴吧
  • 用easyui皮肤做漂亮的网站无锡百度正规公司
  • 企业可以做哪些网站nba最新排行榜
  • 如何给网站更换域名企业seo排名费用报价
  • 万云网络网站苏州seo关键词优化方法
  • 怎么更改网站关键词兰州搜索引擎优化
  • 免费推广网站途径有哪些泰安seo公司
  • 建设网站的分析报告武汉百度百科
  • 网站建设报价选兴田德润中国舆情观察网
  • 东莞网站建设推广服务seo标题优化是什么意思
  • 网站开发课程百度客户电话
  • 淘宝客的网站是自己做的吗下载谷歌浏览器并安装
  • 做网站时分类标题和分类描述网站建设策划
  • 做网站需要到什么技术提交网址给百度
  • 沈阳什么行业做网站的最多注册公司流程和费用
  • 张店政府网站建设公司全球搜索
  • 如何在淘宝上做自己的网站关键词排名优化
  • vps正常网站打不开网站推广100种方法
  • 赣州网站建设多少钱巨量算数
  • 手机网站 怎么开发策划营销
  • 做淘宝优惠网站百度关键词检测工具
  • 海口免费自助建站模板网络seo
  • 商务信息网站外贸怎么建立自己的网站
  • 做网站算经商吗超级优化空间
  • 申请网站建设的报告查看浏览过的历史记录百度
  • 广州领域设计网络运营有限公司北京seo公司助力网络营销
  • 淄博建设网站制作网站软件