笔试|二分图最大匹配/最小点覆盖问题(增广路、匈牙利算法)

参考:https://blog.csdn.net/qq_38956769/article/details/80238896

二分图

  • 定义:1)无向图;2)将顶点分为两类,边只存在于两类点之间,不存在于类内顶点间。
    若能将无向图G=(V,E)的顶点V划分为两个交集为空的顶点集,并且任意边的两个端点都分属于两个集合,则称图G为一个为二分图。
  • 判定:如果一个图是连通的,可以用如下的染色法判定是否二分图:
    我们把X部的结点颜色设为0,Y部的颜色设为1。
    从某个未染色的结点u开始,做BFS或者DFS 。把u染为0,枚举u的儿子v。如果v未染色,就染为与u相反的颜色,如果已染色,则判断u与v的颜色是否相同,相同则不是二分图。
    如果一个图不连通,则在每个连通块中作判定。
  • 例子:情侣配对

匹配

在G的一个子图S中,S的边集中的任意两条边都不依附于同一个顶点,则称S是一个匹配。

  • 最大匹配
    有的人有多个意向,无冲突地情况下尽量多撮合成几对。成功配对数最多的匹配为最大匹配。
  • 最优匹配/完美匹配
    若每个人都找到了心仪对象。这种撮合方式,叫做最优匹配或完美匹配。

交替路 & 增广路

用于解决新配对时的冲突。交替路即非匹配边、匹配边交替。
一个一个找匹配,出现冲突时,找首尾都是非匹配边的交替路(即,增广路) ,找到后将其取反,此时得到新匹配,匹配点比原先多1个。

匈牙利算法:不断利用增广路找更好的匹配

  • 每个点从另一个集合里挑对象,没冲突的话就先安排上,要是冲突了就用增广路径重新匹配。重复上述思路,直到所有的点都找到对象,或者找不到对象也找不到增广路。
  • 深度优先和广度优先
    上述是深度优先匈牙利算法。就是冲突了立刻用增广路来解决。
    另外一种是广度优先匈牙利算法。思路是,冲突了就换一个心仪对象,看另一个心仪对象是不是也配对了,要是都配对了,再用增广路来解决。
  • 核心:找增广路(DFS)
    对于每个可以与u匹配的顶点v,假如v未被匹配,那直接用 v与u匹配;
    如果v已与顶点w匹配,那么调用DFS(w)来求证w是否可以与其它顶点匹配,如果DFS(w)返回 true的话,使v与u匹配;如果DFS(w)返回false,则检查u的下一个邻接点 ······
    在DFS 时,要标记访问过的顶点(vis[j]=true),以防死循环和重复计算;每次在主过程中开始一次DFS前,所有的顶点都是未标记。
    主过程只需对每个X部的顶点调用DFS ,如果返回一次 true,就对最大匹配数加一;一个简单的循环就求出了最大匹配数目。
/************深搜找增广路************/
bool Vis[MAX_N+1];
int Match[MAX_N+1];
bool Dfs(int u){
    for(int i=0;i<Adj[u].size();i++){
        int v=Adj[u][i];
        if(Vis[v])  
            continue;
        Vis[v]=true;
        if(!Match[v]||Dfs(Match[v])){
            Match[v]=u;
            Match[u]=v;
            return true;
        }
    }
    return false;
}
/*********匈牙利算法主函数**********/
void Solve(){
    for(int i=1;i<=n;i++){
        memset(Vis,false,sizeof(Vis));
        if(!Match[i])
            if(Dfs(i))
                ans++;
    }
}

König定理

二分图最小点覆盖的点的数量等于二分图最大匹配的边的数量,即最小点覆盖=最大匹配数。
最小边覆盖(最小的覆盖所有点的边集)=最大独立集(点集,当且仅当它不被包含在一个更大的点集中时)=总节点数-最大匹配数

  • 𝐷𝑖𝑛𝑖𝑐 算法
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 206,378评论 6 481
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 88,356评论 2 382
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 152,702评论 0 342
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 55,259评论 1 279
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 64,263评论 5 371
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,036评论 1 285
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,349评论 3 400
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,979评论 0 259
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,469评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,938评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,059评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,703评论 4 323
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,257评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,262评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,485评论 1 262
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,501评论 2 354
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,792评论 2 345

推荐阅读更多精彩内容