8288分类目录 8288分类目录 8288分类目录
  当前位置:海洋目录网 » 站长资讯 » 站长资讯 » 文章详细 订阅RssFeed

二分图匹配模板(dfs+bfs)

来源:本站原创 浏览:125次 时间:2021-10-13

dfs版:

 

[cpp] view plain copy print?

  1. bool dfs(int u)  
  2. {  
  3.     for(int i = head[u]; ~i; i = e[i].next) {  
  4.         int v = e[i].v;  
  5.         if(!vis[v]) {  
  6.             vis[v] = true;  
  7.             if(my[v] == -1 || dfs(my[v])) {  
  8.                 my[v] = u;  
  9.                 mx[u] = v;  
  10.                 return true;   
  11.             }  
  12.         }  
  13.     }  
  14.     return false;  
  15. }  
  16.   
  17. int hungary()  
  18. {  
  19.     int ret = 0;  
  20.     memset(mx, -1, sizeof(mx));  
  21.     memset(my, -1, sizeof(my));  
  22.     for(int i = 1; i <= X; i++) {  
  23.         if(mx[i] == -1) {  
  24.             memset(vis, 0, sizeof(vis));  
  25.             if(dfs(i)) ret++;  
  26.         }  
  27.     }  
  28.     return ret;  
  29. }  

 

bfs版:

[cpp] view plain copy print?

    1. bool bfs(int st)  
    2. {  
    3.     queue <int> q;  
    4.     q.push(st);  
    5.     pre[st] = -1;  
    6.     bool flag = false;  
    7.     while(!q.empty() && !flag) {  
    8.         int u = q.front(); q.pop();  
    9.         for(int i = head[u]; ~i && !flag; i = e[i].next) {  
    10.             int v = e[i].v;  
    11.             if(vis[v] != st) {  
    12.                 vis[v] = st;  
    13.                 q.push(my[v]);  
    14.                 if(~my[v]) pre[my[v]] = u;  
    15.                 else {  
    16.                     int a = u, b = v;  
    17.                     flag = true;  
    18.                     while(~a) {  
    19.                         int t = mx[a];  
    20.      ���겻��,���겻��                   mx[a] = b;  
    21.                         my[b] = a;  
    22.                         a = pre[a];  
    23.                         b = t;  
    24.                     }  
    25.                 }  
    26.             }  
    27.         }  
    28.     }  
    29.     return mx[st] != -1;  
    30. }  
    31.   
    32. int hungary()  
    33. {  
    34.     int ret = 0;  
    35.     memset(mx, -1, sizeof(mx));  
    36.     memset(my, -1, sizeof(my));  
    37.     memset(vis, -1, sizeof(vis));  
    38.     for(int i = 1; i <= nX; i++) {//number from 1  
    39.         if(mx[i] == -1) {  
    40.             if(bfs(i)) ret++;  
    41.         }  
    42.     }  
    43.     return ret;  

  推荐站点

  • At-lib分类目录At-lib分类目录

    At-lib网站分类目录汇集全国所有高质量网站,是中国权威的中文网站分类目录,给站长提供免费网址目录提交收录和推荐最新最全的优秀网站大全是名站导航之家

    www.at-lib.cn
  • 中国链接目录中国链接目录

    中国链接目录简称链接目录,是收录优秀网站和淘宝网店的网站分类目录,为您提供优质的网址导航服务,也是网店进行收录推广,站长免费推广网站、加快百度收录、增加友情链接和网站外链的平台。

    www.cnlink.org
  • 35目录网35目录网

    35目录免费收录各类优秀网站,全力打造互动式网站目录,提供网站分类目录检索,关键字搜索功能。欢迎您向35目录推荐、提交优秀网站。

    www.35mulu.com
  • 就要爱网站目录就要爱网站目录

    就要爱网站目录,按主题和类别列出网站。所有提交的网站都经过人工审查,确保质量和无垃圾邮件的结果。

    www.912219.com
  • 伍佰目录伍佰目录

    伍佰网站目录免费收录各类优秀网站,全力打造互动式网站目录,提供网站分类目录检索,关键字搜索功能。欢迎您向伍佰目录推荐、提交优秀网站。

    www.wbwb.net