二分匹配最大匹配的理解(附圖解)

? 定義
一個PXP的有向圖中,路徑覆蓋就是在圖中找一些路徑,使之覆蓋了圖中的所有頂點,且任何一個頂點有且只有一條路徑與之關聯;(如果把這些路徑中的每條路徑從它的起始點走到它的終點,那么恰好可以經過圖中的每個頂點一次且僅一次);如果不考慮圖中存在回路,那么每條路徑就是一個弱連通子集.
由上面可以得出:
1.一個單獨的頂點是一條路徑;
2.如果存在一路徑p1,p2,......pk,其中p1 為起點,pk為終點,那么在覆蓋圖中,頂點p1,p2,......pk不再與其它的頂點之間存在有向邊.
路徑覆蓋與二分圖匹配的關系(必須是有向無環圖):
最小路徑覆蓋=|P|-最大匹配數

也就是說匈牙利算法將一個二分匹配模型轉換成了一個有向圖的關系(u->v)存在了二維數組中!最后通過linker[u]數組的值,我們知道是選擇了linker[u] -> u這一條有向邊的匹配關系!也就是有多少個非負的linker[u]的個數,就有多少個匹配的關系!如果不存在回路,那么這些linker[u] -> u有向邊關系所構成的弱聯通的子集的個數就是最小路徑覆蓋的個數!


?

?

轉載于:https://www.cnblogs.com/hujunzheng/p/3917855.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/531741.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/531741.shtml
英文地址,請注明出處:http://en.pswp.cn/news/531741.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

poj 2226 Muddy Fields(合理建圖+二分匹配)

1 /*2 題意:用木板蓋住泥濘的地方,不能蓋住草。木板任意長!可以重疊覆蓋! *表示泥濘的地方,.表示草!3 思路:4 首先讓我們回憶一下HDU 2119 Matrix這一道題,一個矩陣…

java驗證碼工具_java 驗證碼工具

importjavax.imageio.ImageIO;import java.awt.*;importjava.awt.image.BufferedImage;importjava.io.IOException;importjava.io.OutputStream;importjava.util.Random;public classCaptchaUtils {private final static Object lock newObject();/*** 圖片的寬度。*/private …

Floyd算法的理解

轉載于:https://www.cnblogs.com/hujunzheng/p/3919226.html

http get post java_java發送http的get、post請求實現代碼

Http請求類package wzh.Http;import java.io.BufferedReader;import java.io.IOException;import java.io.InputStreamReader;import java.io.PrintWriter;import java.net.URL;import java.net.URLConnection;import java.util.List;import java.util.Map;public class HttpRe…

java string的作用_淺談java String不可變的好處

一、java內部String類的實現:java 8:public final class Stringimplements java.io.Serializable, Comparable, CharSequence {/** The value is used for character storage. */private final char value[];}java 9 及之后:(使用coder標識了…

34988 Happy Reversal(二進制去取反)

1 /*2 題意:給多個二進制數,對某些數進行按位取反操作!3 然后從中找到最大數和最小數,并輸出他們的差值! 4 注意:所有的數都是整數,包括取反之后5 6 思路:一個n為二進…

java vim ide_Vim配置Java IDE

首先安裝vim (當然做java 開發要裝jdk 這個就不說了)emerge -av vim (gentoo 系統上安裝vim 的命令,你可以用rpm ,apt-get )給vim 安裝 javacomplete 插件http://www.vim.org/scripts/script.php?script_id1785 這個插件的作用是實現一部分代碼提示功能 比如你輸入 System…

java中線程存活和線程執行的問題!

1 /*2 下面的程序會出現下面的情況,當Thread-0, Thread-1, Thread-2都被wait的時候,可能會同時蘇醒3 Thread-0 put4 Thread-1 put5 Thread-2 put6 Thread-3 get//在此處,Thread-3拿到鎖之后&#xff0…

java中多線程模擬(多生產,多消費,Lock實現同步鎖,替代synchronized同步代碼塊)...

import java.util.concurrent.locks.*; class DuckMsg{int size;//烤鴨的大小String id;//烤鴨的廠家和標號DuckMsg(){}DuckMsg(int size, String id){this.sizesize;this.idid;}public String toString(){return id " 大小為:" size;} } class Duck{private int …

java encode 空格_javaWeb中URLEncoder.encode空格問題

近期開發一個在線坐席的功能。發現推送的消息中空格變成了 。查詢發現URLEncoder.encode的問題。曾經用的時候也沒注意過,解決的方法網上是對URLEncoder.encode的之后的字符串進行替換號,這樣的方式假設真的有號那也被替換了。所以應該在URLEncoder.enco…

poj 1386 Play on Words(有向圖歐拉回路)

1 /*2 題意:單詞拼接,前一個單詞的末尾字母和后一個單詞的開頭字母相同3 思路:將一個單詞的開頭和末尾單詞分別做兩個點并建一條有向邊!然后判斷是否存在歐拉回路或者歐拉路 4 5 再次強調有向圖歐拉路或歐拉回路的判定方法&…

java web tomcat 實例_Java Web應用開發實例

[1.GIS的概念 1.1什么是gis 地理信息系統 (GIS, Geographic Information System) 是一種基于計算機的工具,它可以對在地球上存在的東西和發生的事件進行成圖和分析。 GI上次提到了EclipseTomcatLomboz Java Web開發環境的配置,可環…

poj2513Colored Sticks(無向圖的歐拉回路)

1 /*2 題意:將兩端涂有顏色的木棒連在一起,并且連接處的顏色相同!3 思路:將每一個單詞看成一個節點,建立節點之間的無向圖!判斷是否是歐拉回路或者是歐拉路4 5 并查集判通 奇度節點個數等于2或…

java java.lang.enum_源碼閱讀-java基礎-java.lang.Enum

1、引言枚舉類型是 JDK 5 之后引進的一種非常重要的引用類型,可以用來定義一系列枚舉常量。相比與常量(public static final定義),在安全性、指意性、可讀性方面更勝一籌。另外它可以和switch case搭配使用。2、類定義實際上在使用關鍵字enum創建枚舉類型…

java中有關線程的題目

1,看一下下面程序錯誤發生在哪一行! class Test implements Runnable{public void run(Thread t){} }2,輸出結果是什么? class Test{public static void main(String[] args){new Thread(new Runnable(){public void run(){System…

java 可逆的加密算法_java實現AES可逆加密算法

package com.hdu.encode;import javax.crypto.Cipher;import javax.crypto.spec.IvParameterSpec;import javax.crypto.spec.SecretKeySpec;import sun.misc.BASE64Decoder;import sun.misc.BASE64Encoder;/*** AES 是一種可逆加密算法,對用戶的敏感信息加密處理 對…

森林轉換成二叉樹以及二叉樹還原為森林代碼

1 /*2 森林轉換成二叉樹3 思路:u的孩子節點為v1, v2, v3....(v1,v2,....互為兄弟節點) 4 那么將u的一個孩子節點(v1)連在u的左子樹上,那么其他的孩子節點都連在v1的右子樹上! 5 …

poj1062昂貴的聘禮(Dijkstra**)

1 /*2 題意: 物主有一個物品,價值為P,地位為L, 以及一系列的替代品Ti和該替代品所對應的"優惠"Vi3 g[u][i] 表示的是u物品被i物品替換后的優惠價格!(u>0, i>0)4 g[u][0]表示不用替換該物品的…

java openmp庫_OpenMP的環境變量及庫函數

OpenMP的環境變量:環境變量 描述 示例OMP_SCHEDULE 控制for循環任務分配結構的調度 OMP_SCHEDULE"guided,2"OMP_NUM_THREADS 設置默認線程的個數 OMP_SCHEDULE4OpenMP的庫函數函數名稱 描述int omp_get_num_threads(void) 返回當前使用的線程個數&#xf…

hdu1269迷宮城堡(判斷有向圖是否是一個強連通圖)

1 /* 題意: 給你一個圖,求這個有向圖示否是一個強連通圖(每兩個節點都是可以相互到達的)! 思路1:按正向邊dfs一遍,將經過的節點計數,如果記錄的節點的個數小于…