python有向图遍历_Networkx:随机遍历有向图

我有一个带加权边的有向图。每个节点连接到其他节点,权重表示从节点X移动到节点Y的可能性(每个节点的权重之和=1-这是一个随机矩阵)。在

我需要创建一个函数,它随机遍历图,并且只进出每个节点一次,返回到起始点

我不想返回最有可能的输出,只是第一次随机遍历树,它只访问每个节点一次,然后返回它所走的路径,以及每跳一次的可能性。在

下面是我要寻找的一个简单实现:import pandas as pd

import numpy as np

from numpy.random import choice

import networkx as nx

testData = [('A','B',.5),('A','C',.4),('A','D',.1),('B','A',.5),('B','C',.3),('B','D',.2),('C','A',.3),('C','B',.1),

('C','D',.6),('D','A',.35),('D','B',.15),('D','C',.5)]

G = nx.DiGraph()

G.add_weighted_edges_from(testData)

#traverse g from randomly selected starting node to every other node randomly and back to random start node

def randomWalk(g):

start_node = choice(G.nodes())

#dfs implementation available?

return pathTaken

print (randomWalk(G))

>>> [('C','A',.3),('A':'D',.1),('D':'B',.15),('B':'C',.3)]

我找不到一种方法来将随机行走组件合并到任何可用的遍历算法中。在

对我可以使用的可用实现有什么想法吗?如果可以避免的话,我宁愿不写自定义的DFS。。。在

谢谢!在

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值