gpt4 book ai didi

Python 判断 有向图 是否有环的实例讲解

转载 作者:qq735679552 更新时间:2022-09-28 22:32:09 26 4
gpt4 key购买 nike

CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.

这篇CFSDN的博客文章Python 判断 有向图 是否有环的实例讲解由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.

实例如下:

?
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
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
import numpy
from numpy import *
def dfs( v ):
  vis[v] = -1
  flag = 0
  for i in range(n):
  # print (a[v][i],'---', vis[i] )
  if a[v][i] != 0 and vis[i] != -1:
   dfs(i)
   vis[i] = 1
  else:
   pass
  if a[v][i] != 0 and vis[i] == -1:
   print ('Yes, there is A loop in this network\n')
   global swi
   swi = True
   exit()
   return
   # break
  else:
   pass
  print ('s = 0')
  return False
 
global swi
swi = False
'''===装载数据'''
edges = numpy.loadtxt('9_nodes_with_r_edge_8_to_3.txt')
 
# edges = [ int(i) for i in edges]
bian = int(shape(edges)[0]) - 1
print (bian,'edges in the network \n')
print (shape(edges),'\n')
 
n = int( edges[0][1] )
 
c = int( edges[0][0] )
# n, c = input().split()
# n = int(n)
# c = int(c)
a = [([0] * n) for i in range(n)]
vis = [0] * c
for i in range(1, c+1):
  s, t = edges[i][0:2]
  # print (s,' - ', t )
  '''GO_OBO文件则 s, t 不需要 -1 '''
  s = int(s) - 1
  t = int(t) - 1
  # s = int(s)
  # t = int(t)
  a[s][t] = 1
# print (a)
# print (vis)
dfs(0)
# print (swi)
if not swi:
  print('No loop, DAG - DAG - DAG')

用到 numpy 模块,读取的 txt 文件为 有向图的连边,其中第一行 第一个数字 为 边的数量,第二个数字为 节点数 第二行及以后 前两个数字,第一个为 起点, 第二个为 落点.

以上这篇Python 判断 有向图 是否有环的实例讲解就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持我.

原文链接:http://blog.csdn.net/sinat_35496345/article/details/70215842 。

最后此篇关于Python 判断 有向图 是否有环的实例讲解的文章就讲到这里了,如果你想了解更多关于Python 判断 有向图 是否有环的实例讲解的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com