Python 中的 Hopcroft–Karp 算法

2023-11-27

我正在努力实施霍普克罗夫特卡普算法在Python中使用networkx作为图形表示。

目前我到目前为止:

#Algorithms for bipartite graphs

import networkx as nx
import collections

class HopcroftKarp(object):
    INFINITY = -1

    def __init__(self, G):
        self.G = G

    def match(self):
        self.N1, self.N2 = self.partition()
        self.pair = {}
        self.dist = {}
        self.q = collections.deque()

        #init
        for v in self.G:
            self.pair[v] = None
            self.dist[v] = HopcroftKarp.INFINITY

        matching = 0

        while self.bfs():
            for v in self.N1:
                if self.pair[v] and self.dfs(v):
                    matching = matching + 1

        return matching

    def dfs(self, v):
        if v != None:
            for u in self.G.neighbors_iter(v):
                if self.dist[ self.pair[u] ] == self.dist[v] + 1 and self.dfs(self.pair[u]):
                    self.pair[u] = v
                    self.pair[v] = u

                    return True

            self.dist[v] = HopcroftKarp.INFINITY
            return False

        return True

    def bfs(self):
        for v in self.N1:
            if self.pair[v] == None:
                self.dist[v] = 0
                self.q.append(v)
            else:
                self.dist[v] = HopcroftKarp.INFINITY

        self.dist[None] = HopcroftKarp.INFINITY

        while len(self.q) > 0:
            v = self.q.pop()
            if v != None:
                for u in self.G.neighbors_iter(v):
                    if self.dist[ self.pair[u] ] == HopcroftKarp.INFINITY:
                        self.dist[ self.pair[u] ] = self.dist[v] + 1
                        self.q.append(self.pair[u])

        return self.dist[None] != HopcroftKarp.INFINITY


    def partition(self):
        return nx.bipartite_sets(self.G)

该算法取自http://en.wikipedia.org/wiki/Hopcroft%E2%80%93 卡普算法然而它不起作用。我使用以下测试代码

G = nx.Graph([
(1,"a"), (1,"c"),
(2,"a"), (2,"b"),
(3,"a"), (3,"c"),
(4,"d"), (4,"e"),(4,"f"),(4,"g"),
(5,"b"), (5,"c"),
(6,"c"), (6,"d")
])

matching = HopcroftKarp(G).match()

print matching

不幸的是,这不起作用,我最终陷入了无限循环:(。有人能发现这个错误吗,我没有想法,我必须承认我还没有完全理解该算法,所以它主要是伪的实现维基百科上的代码


线路

if self.pair[v] and self.dfs(v):

应该

if self.pair[v] is None and self.dfs(v):

根据维基百科页面上的伪代码。我看到的唯一另一个问题是您将双端队列用作堆栈,并且希望将其用作队列。为了解决这个问题,你只需要向左弹出而不是弹出(向右弹出)。所以这条线

v = self.q.pop()

应该

v = self.q.popleft()

希望其他一切都有效。我只是检查你的 Python 代码的工作方式是否与维基百科上的伪代码相同,所以希望伪代码是正确的。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

Python 中的 Hopcroft–Karp 算法 的相关文章

随机推荐