新书推介:《语义网技术体系》
作者:瞿裕忠,胡伟,程龚
   XML论坛     W3CHINA.ORG讨论区     计算机科学论坛     SOAChina论坛     Blog     开放翻译计划     新浪微博  
 
  • 首页
  • 登录
  • 注册
  • 软件下载
  • 资料下载
  • 核心成员
  • 帮助
  •   Add to Google

    >> We choose to study algorithmic problems,  not because they are easy,  but because they are hard.
    [返回] 中文XML论坛 - 专业的XML技术讨论区计算机理论与工程『 算法理论与分析 』 → 请教解"maximum cardinality with maximum weight in bipartite graph"的算法? 查看新帖用户列表

      发表一个新主题  发表一个新投票  回复主题  (订阅本版) 您是本帖的第 10100 个阅读者浏览上一篇主题  刷新本主题   树形显示贴子 浏览下一篇主题
     * 贴子主题: 请教解"maximum cardinality with maximum weight in bipartite graph"的算法? 举报  打印  推荐  IE收藏夹 
       本主题类别:     
     csdncannon 帅哥哟,离线,有人找我吗?
      
      
      威望:1
      等级:大三(研究MFC有点眉目了!)
      文章:70
      积分:621
      门派:XML.ORG.CN
      注册:2006/2/17

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给csdncannon发送一个短消息 把csdncannon加入好友 查看csdncannon的个人资料 搜索csdncannon在『 算法理论与分析 』的所有贴子 引用回复这个贴子 回复这个贴子 查看csdncannon的博客楼主
    发贴心情 请教解"maximum cardinality with maximum weight in bipartite graph"的算法?

    是否可以转化成最小费用最大流来做?

    有更好的办法吗?


       收藏   分享  
    顶(0)
      




    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2006/6/17 14:24:00
     
     Logician 帅哥哟,离线,有人找我吗?天蝎座1984-10-28
      
      
      威望:9
      头衔:逻辑爱好者
      等级:研三(收到IBM CRL的Offer了)(版主)
      文章:1219
      积分:10357
      门派:IEEE.ORG.CN
      注册:2005/3/12

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给Logician发送一个短消息 把Logician加入好友 查看Logician的个人资料 搜索Logician在『 算法理论与分析 』的所有贴子 点击这里发送电邮给Logician  访问Logician的主页 引用回复这个贴子 回复这个贴子 查看Logician的博客2
    发贴心情 
    能具体叙述一下问题吗?

    ----------------------------------------------
    Three passions, simple but overwhelmingly strong, 
    have governed my life: the longing for love, the
    search for knowledge, and unbearable pity for the
    suffering of mankind.
                                - Bertrand Russell

    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2006/6/17 19:10:00
     
     shiyr 帅哥哟,离线,有人找我吗?
      
      
      等级:大一新生
      文章:8
      积分:97
      门派:XML.ORG.CN
      注册:2005/10/27

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给shiyr发送一个短消息 把shiyr加入好友 查看shiyr的个人资料 搜索shiyr在『 算法理论与分析 』的所有贴子 引用回复这个贴子 回复这个贴子 查看shiyr的博客3
    发贴心情 
    最小费用最大流的方法已经是最优的了

    采用连续最短路算法 + 线性规划对偶性优化的原始对偶算法和最大权匹配的KM算法都是O(n3)

    而且最小费用最大流又较KM好写 ... 所以推荐最小费用最大流 ...

    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2006/6/18 21:30:00
     
     phoenixinter 帅哥哟,离线,有人找我吗?水瓶座1987-2-12
      
      
      威望:1
      头衔:Ikki
      等级:大四(GRE考了1600分!)(版主)
      文章:127
      积分:1126
      门派:Lilybbs.net
      注册:2005/3/14

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给phoenixinter发送一个短消息 把phoenixinter加入好友 查看phoenixinter的个人资料 搜索phoenixinter在『 算法理论与分析 』的所有贴子 点击这里发送电邮给phoenixinter  引用回复这个贴子 回复这个贴子 查看phoenixinter的博客4
    发贴心情 
    最优匹配问题,采用KM算法,复杂度O(n^3)
    效果远胜最小费用最大流,而且很好写。

    /*
      Hungary 算法求二部图的最优匹配
      输入:C  -- 二部图的利润矩阵,C[x][y] >=0 表示x和y匹配的利润,
                 若x和y之间没有边则C[x][y]=0
           nx -- 二部图的节点集合X中的元素数目
           ny -- 二部图的节点集合Y中的元素数目
      输出:X, Y -- 最优匹配中X,Y集合中节点所匹配的节点的id,-1表示该节点没有被匹配
                   注意,若C[i][X[i]] = 0,则最终的结果中可以删除这一匹配,因为
            有无这一匹配对最大利润没有影响
      复杂度:
      注意:输入必须保证 C[x][y] >= 0       
    */
    void optmatch(Graph C, int nx, int ny, Path X, Path Y)
    {
        Path Lx, Ly, Q, prev;
        int i, j, k, s, head, tail;

        // 要保证Y中的节点数目比X中的多,从而使X中的所有节点都可以被匹配
        if (ny < nx) ny = nx;  

        for (i = 0; i < nx; i++) {
     Lx[i] = Ly[i] = 0;
     for (j = 0; j < ny; j++) {
         Lx[i] = max(Lx[i], C[i][j]);
     }
        }    
        memset(X, -1, sizeof(Path));
        memset(Y, -1, sizeof(Path));
        i = 0;
        while (i < nx) {
     memset(prev, -1, sizeof(Path));
     for (Q[0] = i, head = 0, tail = 1; head < tail && X[i] < 0; head++) {
         s = Q[head];
         for (j = 0; j < ny && X[i] < 0; j++) {
      if (Lx[s] + Ly[j] > C[s][j] || prev[j] >= 0) continue;
      Q[tail++]  = Y[j];
      prev[j] = s;
      if (Y[j] < 0) {      
          while (j >= 0) {
       s = prev[j];
       Y[j] = s;
       k = X[s];
       X[s] = j;
       j = k;
          }
      }
         }
     }
     if (X[i] >= 0) {
         i++;
     } else {
         k = INT_MAX;
         for (head = 0; head < tail; head++) {
      s = Q[head];
      for (j = 0; j < ny; j++) {
          if (prev[j] == -1) {
       k = min(k, Lx[s] + Ly[j] - C[s][j]);
          }
      }
         }
         for (j = 0; j < tail; j++) {
      Lx[Q[j]] -= k;
         }
         for (j = 0; j < ny; j++) {
      if (prev[j] >= 0) Ly[j] += k;
         }
     }
        }    
    }

    ----------------------------------------------
    phoenixinter
    algorithm bm@lilybbs
    ikki@poj

    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2006/6/19 18:55:00
     
     shiyr 帅哥哟,离线,有人找我吗?
      
      
      等级:大一新生
      文章:8
      积分:97
      门派:XML.ORG.CN
      注册:2005/10/27

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给shiyr发送一个短消息 把shiyr加入好友 查看shiyr的个人资料 搜索shiyr在『 算法理论与分析 』的所有贴子 引用回复这个贴子 回复这个贴子 查看shiyr的博客5
    发贴心情 
    我记得KM算法是很容易写成N^4的 , 但是效果却和N^3差不多 , 所以一直用有保证的费用流 ...

    但是费用流也十分好写吧 .

    冒昧一下 , 你这个我怎么看都有点像N^4的 ... 不过我不用C 可能看错了 ...

    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2006/6/22 15:00:00
     
     phoenixinter 帅哥哟,离线,有人找我吗?水瓶座1987-2-12
      
      
      威望:1
      头衔:Ikki
      等级:大四(GRE考了1600分!)(版主)
      文章:127
      积分:1126
      门派:Lilybbs.net
      注册:2005/3/14

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给phoenixinter发送一个短消息 把phoenixinter加入好友 查看phoenixinter的个人资料 搜索phoenixinter在『 算法理论与分析 』的所有贴子 点击这里发送电邮给phoenixinter  引用回复这个贴子 回复这个贴子 查看phoenixinter的博客6
    发贴心情 
    我很负责的告诉你我这个是O(n^3)的

    ----------------------------------------------
    phoenixinter
    algorithm bm@lilybbs
    ikki@poj

    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2006/6/23 21:00:00
     
     shiyr 帅哥哟,离线,有人找我吗?
      
      
      等级:大一新生
      文章:8
      积分:97
      门派:XML.ORG.CN
      注册:2005/10/27

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给shiyr发送一个短消息 把shiyr加入好友 查看shiyr的个人资料 搜索shiyr在『 算法理论与分析 』的所有贴子 引用回复这个贴子 回复这个贴子 查看shiyr的博客7
    发贴心情 
    啊 ... 或许我真是看错了 ... 还是继续写mincostflow算了 ...
    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2006/6/23 22:32:00
     
     salvage 美女呀,离线,快来找我吧!
      
      
      等级:大一新生
      文章:0
      积分:58
      门派:XML.ORG.CN
      注册:2007/5/24

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给salvage发送一个短消息 把salvage加入好友 查看salvage的个人资料 搜索salvage在『 算法理论与分析 』的所有贴子 引用回复这个贴子 回复这个贴子 查看salvage的博客8
    发贴心情 
    请教一下
    什么是连续最短路算法 + 线性规划对偶性优化的原始对偶算法
    最近刚开始看有关最大流算法的文章
    有个问题始终搞不懂
    原始对偶算法是如何与迭代算法结合起来的?
    迭代的限制条件又是如何列出的?
    哪位好心人指点一下啊
    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2007/5/24 20:44:00
     
     GoogleAdSense
      
      
      等级:大一新生
      文章:1
      积分:50
      门派:无门无派
      院校:未填写
      注册:2007-01-01
    给Google AdSense发送一个短消息 把Google AdSense加入好友 查看Google AdSense的个人资料 搜索Google AdSense在『 算法理论与分析 』的所有贴子 访问Google AdSense的主页 引用回复这个贴子 回复这个贴子 查看Google AdSense的博客广告
    2025/1/21 17:50:00

    本主题贴数8,分页: [1]

    管理选项修改tag | 锁定 | 解锁 | 提升 | 删除 | 移动 | 固顶 | 总固顶 | 奖励 | 惩罚 | 发布公告
    W3C Contributing Supporter! W 3 C h i n a ( since 2003 ) 旗 下 站 点
    苏ICP备05006046号《全国人大常委会关于维护互联网安全的决定》《计算机信息网络国际联网安全保护管理办法》
    93.750ms