【问题标题】:Max-flow Application: rearrange matrix最大流量应用:重新排列矩阵
【发布时间】:2013-04-08 02:17:17
【问题描述】:

M,一个 n x n 矩阵,每个条目等于 0 或 1。mij 表示第 i 行和第 j 列中的条目。对角线条目是其中之一 对某些 i 形成 mii。 交换矩阵 M 的 i 和 j 行表示以下动作: 我们将值 mik 和 mjk 交换为 k = 1, 2 ..... n。交换两列 类似地定义。 我们说 M 如果可以交换一些 成对的行和一些成对的列(以任何顺序),这样, 在所有交换之后,M的所有对角线条目都等于1。

我需要找到一个多项式时间算法来确定一个矩阵是否 具有 0-1 个条目的 M 是可重新排列的。

我知道我必须使用 max-flow/min-cut 范例来解决这个问题,但我找不到将这个问题与 max-flow 问题联系起来的方法。

欢迎任何提示!

【问题讨论】:

    标签: algorithm


    【解决方案1】:

    直接证明矩阵是可重排的当且仅当在 Sn 中存在置换 pi 使得 Mi, pi(i) = 1对于每个 i。

    这样的排列只是二分图中的完美匹配,每行有一个顶点,每列有一个顶点,当 Mij = 1 时,第 i 行和第 j 列之间有一条边.

    使用 max-flow 在二分图中找到最大匹配非常简单;当最大匹配是完美匹配时,您就有一个可重新排列的矩阵。

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2020-04-08
      • 1970-01-01
      • 1970-01-01
      • 2012-06-11
      • 2017-08-23
      相关资源
      最近更新 更多