矩陣胚的定義是: M={S,I} ,其中 S 為有限集, I 為 S 的一個子集族,滿足下麵條件:1. {} 屬於 I ;2.如果集合 X 屬於 I ,則 X 的所有子集都屬於 I ;3.如果集合 W,V 都屬於 I ,且 |V|>|W| ,則 V 中存在一個不在 W 中的集合 z ,使 W 並 {z} 屬於 I 。 I 中的集合叫做矩陣胚的獨立子集。
基本介紹
- 中文名:矩陣胚
- 外文名:matroid
- 適用範圍:數理科學
簡介,屬性,定理1,定理2,
簡介
1、空集𝒫 。
2、若𝒫,則𝒫。
3、若𝒫,|X|=|Y|+1,則存在,使𝒫(這裡 |X| 表示 X 中元素個數)
則稱(E,𝒫)為一個擬陣即矩陣胚。
滿足上述條件 1 和 2 的(E,𝒫)稱為一個獨立系,擬陣首先在圖論研究中引起注意,它使圖論中某些概念易於理解,產生了許多新的結果,並使原有若干證明大為簡化,在組合最佳化中也有重要套用,特別是三個以上擬陣交的獨立系統問題至今仍是難題。它的研究對於最短路問題、最小樹形問題、旅行商問題等均有重要意義。
屬性
上面三個定義保證了獨立子集具有如下屬性:
1.獨立子集至少有一個(空集)
2.獨立子集是“遺傳”的。
3.只要一個獨立子集不是最大(元素最多)的,我們總可以把它變得更大。
定義:把 S 中的元素加非負的權,我們可以得到一個加權矩陣胚。
定理1
貪心的擴展加權矩陣胚可以得到最優子集。
證明:設貪心法得到的獨立子集是 B ,最優獨立子集為 T(如果有多個 T ,選擇使 B 交 T 最大的那個),那么:
i)如果 B=T ,則成功;
ii)否則,設 x 為不在 T 中的第一個被貪心法選擇的元素,則 T 並 x 為非獨立集(否則與 T 最大矛盾)。
設 C 為 T 並 x 的子集中的最小的非獨立集,則 x 屬於 C (否則 C 就為 T 的子集,與屬性 2 矛盾)。這樣,我們取 C中任意不屬於 B 的元素 y ,又條件 3 , C-{y} 為獨立集。
下面從 C-{y} 出發構造一個最優獨立子集 T1,使 B 交 T1 比 B 交 T 更大。
對於 C-{y} ,我們把 T 中不屬於其中的元素依次加到裡面(根據屬性 3 ),則最後我們得到一個T1,其中T1=T-{y}+{x}。
下面來說明 w(x)=w(y) 。
1.T是最優的,因此 w(T1)≤w(T),即 w(x)<=w(y) ;
2.假設貪心算法選擇 x 之前選擇過的元素集合為 X ,那么: X 為 T 的子集,且 X 並 {y} 也是 T 的子集。那么,在選擇 x 的時候, y 也是可以選的。但是貪心算法選擇的是 x ,必有 w(x)≥w(y) ,故 w(x)=w(y)。
這樣,T1也是最優獨立子集,但是 T1比 T 多一個在 B 中的元素 x ,與 T 的選擇矛盾。故貪心法能夠選擇最優獨立子集。
定理2
如果F關於子集運算是封閉的,而對於任何權函式(F,w),貪心法都適用,則F為某個矩陣胚的獨立子集族。
兩個常用的獨立子集的例子是:
1.有限個n維向量集合中個線性無關的向量 。
2.某個圖中沒有圈的邊集。
根據定理一,我們如果可以把問題歸結成在加權矩陣胚中求最優獨立子集的問題(需要驗證問題的結構滿足矩陣胚的三個定義),就可以採用貪心法。也就是每次選取權值最優的元素加到獨立子集中,最後得到的最大獨立子集必然是最優的。