云南大學(xué)報告問題、模型與算法.ppt
《云南大學(xué)報告問題、模型與算法.ppt》由會員分享,可在線閱讀,更多相關(guān)《云南大學(xué)報告問題、模型與算法.ppt(57頁珍藏版)》請在裝配圖網(wǎng)上搜索。
問題、模型與求解算法,云南大學(xué)數(shù)學(xué)系李建平二OO九年十一月,內(nèi)容摘要,基礎(chǔ)知識最小支撐樹問題最短路問題匹配問題歐拉問題中國郵遞員問題一些可計算性為NP-完備的組合最優(yōu)化問題及數(shù)學(xué)模型,一、基礎(chǔ)知識,1.1圖與支撐子圖定義1.1所謂一個(無向)圖是指給了一個集合V,以及V中的不同元素的無序?qū)?gòu)成的集合E,并記圖為G=(V,E)。稱V中的元素為圖G的頂點,稱E中的元素為圖G的邊。連接兩頂點u和v的邊記作uv(或者vu),也稱邊uv(或者vu)與頂點u,v相關(guān)聯(lián),同時稱兩頂點u和v是相鄰的。,,,,,,,,,,太原,重慶,武漢,南京,徐州,連云港,上海,鄭州,石家莊,塘沽,青島,濟南,天津,北京,圖1.1,定義1.2所謂一個有向圖是指給了一個集合V,以及V中的不同元素的有序?qū)?gòu)成的集合A,并記有向圖為D=(V,A)。稱V中的元素為有向圖D的頂點,稱A中的元素為有向圖D的弧。以頂點u為起點和以頂點v為終點的弧記作(u,v),也稱與弧(u,v)與頂點u,v相關(guān)聯(lián)。,,,,,,,,,v3,v1,v2,v4,v6,v5,圖1.2,定義1.3給定兩個圖G=(V,E)和H=(V*,E*),稱H是G的一個支撐(生成)子圖,如果V*=V和E*E。1.2圖的連通性定義1.4(路)給定圖G=(V,E),一個點、邊交錯的序列P=(v0,e1,v1,e2,v2,e3,v3,…,vk-1,ek,vk),如果滿足ei=vi-1vi,i=1,2,…,k,則稱P為一條連結(jié)v0和vk的路,簡記為P=v0v1v2v3…vk-1vk;稱v0,vk分別稱為路P的起點和終點,其余稱為中間點。,定義1.5(回路)設(shè)P為一條連結(jié)v0和vk的路,如果v0=vk,稱該路P為回路;如果v0≠vk,稱該路P為(嚴格的)路。定義1.6(圈)如果路P除起點和終點相同,中間所含的點均不相同,稱這樣的回路P為圈。定義1.7(連通圖)如果圖G中任意兩點之間均至少有一條路相連,稱G為連通圖;否則稱圖為不連通圖。問題1.1:給定圖G,問G是連通的嗎?,二、最小支撐樹問題,2.1樹定義2.1一個無圈的連通圖稱為樹。樹具有如下一些性質(zhì):性質(zhì)2.1設(shè)圖G=(V,E)是一棵樹,n≥2,則圖G中至少有兩個懸掛點。性質(zhì)2.2圖G=(V,E)是一棵樹的充要條件是G不含圈,并且有且僅有n-1條邊。性質(zhì)2.3圖G=(V,E)是一棵樹的充要條件是G是連通圖,并且有且僅有n-1條邊。性質(zhì)2.4圖G是一棵樹的充分必要條件是任意兩個頂點之間有且僅有一條路。,2.2支撐樹定義2.2設(shè)圖T=(V,E)是圖G=(V,E)的一個支撐子圖,如果圖T=(V,E‘)是一棵樹,那么稱T是G的一棵支撐樹。,,,,,,v6,v5,v2,v3,v4,v1,,,,,,圖2.1,(a),(b),v6,v5,v3,v1,v2,v4,2.3最小支撐樹問題定義2.3設(shè)有圖G=(V,E;w),如果對于G中的每一條邊vivj,相應(yīng)地有一個數(shù)wij,那么稱這樣的圖G為賦權(quán)圖,wij稱為邊vivj的權(quán)。這里所指的權(quán),是具有廣義的數(shù)量值。根據(jù)實際研究問題的不同,可以具有不同的含義。例如長度,費用、流量等等。,定義2.4如果圖T=(V,E)是賦權(quán)圖G的一棵支撐樹,那么E‘中所有邊的權(quán)重之和稱為支撐樹T的權(quán)重,記作w(T)。如果圖G中支撐樹T*的權(quán)重w(T*)是在G的所有支撐樹T中的權(quán)重達到最小者,即w(T*)=min{w(T)|T為G的支撐樹},那么稱T*是G的一棵最小支撐樹。類似可定義最大支撐樹問題。問題2.1:給定圖G,如何求G的一棵最小支撐樹?,常用的有破圈算法和避圈算法:Algorithm破圈算法Input:賦權(quán)圖G=(V,E;w)Output:G的最小支撐樹TBegin①在圖中尋找一個圈。若不存在圈,則已經(jīng)得到最小支撐樹或說明該圖不連通,后者不存在支撐樹(當(dāng)然沒有最小支撐樹);②若存在圈,去掉該圈中權(quán)數(shù)最大的邊;③反復(fù)重復(fù)①、②兩步,直到找到最小支撐樹或說明該圖不連通(故沒有最小支撐樹)。End,,,,,v6,v5,v2,v3,v4,(a),v1,6,2,7,5,3,5,4,4,,,,,,v3,v2,v1,v4,v6,v5,5,1,3,1,4,2,(b),圖2.2,避圈算法:從圖中依次尋找權(quán)重較小的邊,尋找過程中,節(jié)點不得重復(fù),即不得構(gòu)成圈。注意在找較小權(quán)重邊時不考慮已選過的邊和可能造成圈的邊。如此反復(fù)進行,直到得到最小支撐樹或者說明該圖不連通,后者不存在支撐樹(當(dāng)然沒有最小支撐樹)。,2.4頂點加細限制性的最小支撐樹問題定義2.5給定圖G=(V,E),在G的某些邊內(nèi)部增加一些頂點,所得到的新圖稱為原圖G的頂點加細圖(subdivision)。問題2.2(頂點加細限制性的最小支撐樹問題)給定賦權(quán)圖G=(V,E;w)及常數(shù)d,尋找圖G的一棵最小支撐樹T,在T上增加盡可能少的頂點,使得到新的(最?。╉旤c加細支撐樹T*上每條邊的權(quán)重不超過給定的常數(shù)d。,頂點加細限制性的最小支撐樹問題的算法(1).利用已有的算法,對賦權(quán)圖G求最小支撐樹T,記T上權(quán)重大于d的邊為ei1,ei2,…,eik;(2).對邊eij按照下面方式插入insert(eij)頂點,其中當(dāng)w(eij)是d的倍數(shù),取insert(eij)=[w(eij)/d]-1,當(dāng)w(eij)不是d的倍數(shù),取insert(eij)=[w(eij)/d];(3).輸出支撐樹T及插入的頂點。,定理2.1(李建平等,TheoreticalComputerScience410(2009),877-885)上述算法能夠求得頂點加細限制性的最小支撐樹問題的最優(yōu)解,其算法復(fù)雜性就是求最小支撐樹問題的算法復(fù)雜性。,問題2.3(頂點加細限制性的支撐樹問題)給定賦權(quán)圖G=(V,E;w;c),及常數(shù)B和d,尋找圖G的一棵支撐樹T,滿足(1)∑e∈Tw(e)≦B;(2)支撐樹T的頂點加細圖T*上每條邊的權(quán)重不超過給定的常數(shù)d。其目標是使得∑e∈Tinsert(e)﹡c(e)到達最小。,定理2.2(李建平等,TheoreticalComputerScience410(2009),877-885)⑴頂點加細限制性的支撐樹問題是NP-完備的;⑵上述問題多項式等價于限制性的最小支撐樹問題(SIAMJournalonComputing,Vol.33,no.2,261-268,2004);⑶我們能夠設(shè)計多項式時間算法解決頂點加細限制性的支撐樹問題的三種特殊情形,其算法復(fù)雜性就是求最小支撐樹問題的算法復(fù)雜性。,三、最短路問題,3.1最短路問題定義3.1設(shè)有賦權(quán)圖G=(V,E;w),vs,vt是G中的兩個頂點,P是G中從vs到vt的任意一條路,路P的權(quán)重是指P中所有邊的權(quán)重之和,記作w(P)。問題3.1(最短路問題)在所有從vs到vt的路中,尋找一條權(quán)重最小的路P0,即w(P0)=minw(P)。P0稱為從vs到vs的最短路。P0的權(quán)重w(P0)稱為從vs到vt的距離,記作d(vs,vt)。類似可定義賦權(quán)有向圖D中的最短路問題。,3.2反圈定義3.2給定(無向)圖G=(V,E;w),若SV,集合稱為由S確定的反圈(anticircuit)。類似地,有向圖D=(V,A),若SV,集合稱為由S確定的正向反圈,集合稱為由S確定的反向(或逆向)反圈。,3.3一般形式的反圈算法給定圖G=(V,E),設(shè)X(k),E(k)分別是V,E的子集合(初始k=0時,取X(0)是V的某個非空子集合,E(0)為空集合)。若由X(k)確定的反圈不為空集合,根據(jù)某些確定的限制條件,從該反圈中選取一條或多條邊,使得這些所選邊在V-X(k)中的端點互不相同。記被選邊的集合為F(k),它們在V-X(k)中的端點集合為Y(k)。令對,重復(fù)上述過程或者終止。,3.4利用反圈算法求解最短路問題(1)初值X(0)={vs},L(vs)=0;(2)在中選一條邊vivj,使得L(vi)+w(vi,vj)=min{L(vi)+w(vi,vj)}令L(vj)=L(vi)+w(vi,vj)。(3)當(dāng)出現(xiàn)下面情形之一時,停止。當(dāng),得到從vs到vt的最短路;當(dāng),但是,說明沒有從vs到vt的(最短)路。,3.5頂點加細限制性的最短路問題定義3.3(頂點加細限制性的最短路問題)給定賦權(quán)圖G=(V,E;w;vs,vt),及常數(shù)d,尋找圖G中從vs到vt的一條最短路P(vs,vt),在P(vs,vt)上增加盡可能少的頂點,使得到的最短路P(vs,vt)上每條邊的權(quán)重不超過給定的常數(shù)d。,頂點加細限制性的最短路問題的(標號)算法:(1)取X(0)={vs},E(0)=空集,L(vs)=0;(2)在X(k)確定的反圈中選取滿足條件的全部邊uv放入F(k),這里u屬于X(k),v不屬于X(k)L(u)+w(u,v)=min{L(u)+w(u,v)|u屬于X(k),v不屬于X(k)}直到vt屬于某個X(k),轉(zhuǎn)(3);或者無邊可選(停止);,(3)當(dāng)存在vt屬于某個X(k),在E(k)中(遞歸)去掉那些不能到達vt的頂點及其關(guān)聯(lián)的邊;(4)在新圖Gk=(X(k),E(k))中構(gòu)造新的權(quán)重,對邊e屬于E(k),當(dāng)w(e)≦d時,取w(e)=0,當(dāng)w(e)>d時,取w(e)=insert(e),其中當(dāng)w(e)是d的倍數(shù),取insert(e)=[w(e)/d]-1,當(dāng)w(e)不是d的倍數(shù),取insert(e)=[w(e)/d];,(5)相應(yīng)地,在新圖Gk=(X(k),E(k))中,對邊e屬于E(k),當(dāng)w(e)>d時,插入insert(e)個新的頂點;(6)在新圖Gk=(X(k),E(k))中按照新的權(quán)重w,計算從vs到vt的一條最短路P(vs,vt);(7)輸出最短路P(vs,vt)及插入的頂點,這里最短路P(vs,vt)關(guān)于w的權(quán)重就是所求路的權(quán)重,關(guān)于w的權(quán)重就是所增加定點的數(shù)目。,定理3.1(李建平等,submittedtoAlgorithmica2007)上述算法能夠求得限制性的最短路問題的最優(yōu)解,其算法復(fù)雜性就是求最短路問題的算法復(fù)雜性。,問題3.4(頂點加細限制性的最短路問題)給定賦權(quán)圖G=(V,E;w,c;vs,vt),及常數(shù)B和d,尋找圖G中從vs到vt的一條路P(vs,vt),滿足(1)∑e∈P(vs,vt)w(e)≦B;(2)使得路P(vs,vt)的頂點加細圖中每條邊的權(quán)重不超過給定的常數(shù)d。其目標是使得(費用)∑e∈P(vs,vt)insert(e)﹡c(e)到達最小。,定理2.2(李建平等,submittedtoAlgorithmica,2007)⑴頂點加細限制性的最短路問題是NP-完備的;⑵上述問題多項式等價于限制性的最短路問題(MathematicsofOperationsResearch,vol.17,no.1,36-42,1992);⑶當(dāng)B表示圖G中從vs到vt的最短路長度時,我們能夠設(shè)計多項式時間算法解決該問題;⑷當(dāng)只計算頂點加細的數(shù)目時,我們能夠設(shè)計多項式時間算法解決該問題。,四、匹配問題,4.1背景在生活中經(jīng)常會遇到這樣的問題,如某單位需要指派n個人去完成n項任務(wù),每個人只做一項工作,同時,每項工作只由一個人完成。由于各人的專長不同,每個人完成各項任務(wù)的效率也不同。于是產(chǎn)生了應(yīng)指派哪一個人去完成哪一項任務(wù),使完成n項任務(wù)的總效率最高(如所用的時間為最少)。我們把這類問題稱之為指派問題或分派問題(AssignmentProblem)。,求解這樣的問題時,需要引入變量xij,其取值只能是1或0,并令:當(dāng)問題是要求極小化時的數(shù)學(xué)模型是:,4.2匹配問題定義4.1給定圖G=(V,E),如果M是E的子集合,當(dāng)M中任意兩條邊都不相鄰,則稱M是圖G的一個匹配(matching)。當(dāng)圖G的匹配M的元素個數(shù)恰好為頂點數(shù)的一半時,稱M是圖G的完美匹配。,問題4.1(最大基數(shù)匹配問題)尋找圖G的匹配M,使得M中含的元素個數(shù)最多。問題4.2(最優(yōu)匹配問題)對于賦權(quán)圖G=(V,E;w),尋找圖G的匹配M,使得M中含的元素的權(quán)重之和最大。問題4.3(最小或最大完美匹配問題)對于賦權(quán)圖G=(V,E;w),尋找圖G的完美匹配M,使得M中含的邊的權(quán)重之和達到最小(或最大)。,4.3求解二部圖匹配設(shè)G=(S,T;E)是二部圖,能夠用反圈算法來解決二部圖最大匹配問題:設(shè)M為當(dāng)前已有的匹配,(1)初始k=0時,令X(0)={|v是關(guān)于M的非飽和頂點};(2)在中選邊的原則為如果,則選以vi為頂點的非飽和邊如果,則選以vi為頂點的飽和邊;,(3)在某一步,當(dāng)出現(xiàn)下面情形之一時停止:情形1:X(k)中有非飽和的T型點,此時有關(guān)于M的增廣路,則可增廣匹配M(重復(fù)步驟(2));情形2情形1沒有出現(xiàn),但是由X(k)確定的反圈中無邊可選,此時沒有關(guān)于M的增廣路,則M是最大匹配。,定理4.1:設(shè)G是一個圖,M是G的一個匹配,則M是G的最大匹配當(dāng)且僅當(dāng)G中不存在關(guān)于匹配M的增廣路。4.3求解賦權(quán)二部圖完美匹配:匈牙利算法(或最小費用最大流問題的算法)4.4求解一般圖匹配:Edmonds算法4.5求解一般賦權(quán)圖匹配:Edmonds算法,五、歐拉問題,5.1背景德國的哥尼斯堡城有一條普雷格爾河,河中有兩個島嶼,河的兩岸和島嶼之間有七座橋相互連接,如圖5.1所示。1736年瑞士科學(xué)家歐拉發(fā)表了關(guān)于圖論方面的第一篇科學(xué)論文,解決了著名的哥尼斯堡七座橋問題。,,A,B,,,,,,,,,,,,,,,圖5.1,C,D,,,,,,,圖5.2,A,C,D,B,5.2歐拉問題定義5.1給定一個圖G=(V,E),如果存在一條回路C經(jīng)過每條邊恰好一次,稱這樣的圖G是歐拉圖?;芈稢被稱為歐拉回路。問題5.1(歐拉問題)對于給定的圖G=(V,E),判斷圖G是否是歐拉圖?定理5.1(歐拉定理)圖G是歐拉圖當(dāng)且僅當(dāng)G是連通圖,并且G的每個頂點的度為偶數(shù)。,1921年,F(xiàn)leury提供了一個有效的算法來尋找圖G的歐拉回路。以Pk=v1v2…vkvk+1表示第k步得到的路,記Gk=G[E-E(Pk)],如下進行第k+1步:在Gk中選一條邊ek+1=vk+1vk+2,使得ek+1不是圖Gk的割邊(除非dGk(vk+1)=1)。令Pk+1=v1v2…vkvk+1vk+2,及Gk+1=G[E-E(Pk+1)],直到?jīng)]有邊可選。,5.3一筆畫問題問題5.2(一筆畫問題)對于給定的圖G=(V,E),問G是否存在一條路P經(jīng)過每條邊恰好一次?如果G存在這樣的一條路,稱G是可一筆畫的。這時,也稱圖G是M圖。定理5.2圖G是可一筆畫的當(dāng)且僅當(dāng)G是連通圖,并且G中至多存在兩個頂點的度為奇數(shù)。,六、中國郵遞員問題,6.1中國郵遞員問題1960年,中國的數(shù)學(xué)家管梅谷教授提出如下問題:一個郵遞員,每次送信都要走遍他負責(zé)的投遞范圍內(nèi)的每條街道,完成投遞任務(wù)后回到郵局,問他應(yīng)該按照何路線投遞信件,使得所走的總路程之和達到最小?,把這個問題抽象為圖的問題,就是對于給定的連通賦權(quán)圖G=(V,E;w),要尋找G的一個閉回路C,要求C經(jīng)過每條邊至少一次,使得閉回路C中的邊權(quán)重之和達到最小。管梅谷教授在1960年給出了一個判定閉回路C是否是最優(yōu)的一個充分必要條件,但是沒有設(shè)計出有效的算法;Edmonds和Johnson于1973年給出了一個有效的算法來完整地解決了中國郵遞員問題。,Edmonds-Johnson算法:(1)在賦權(quán)圖中找到所有度為奇數(shù)的頂點(共有偶數(shù)個),如v1,v2,…,v2r-1v2r,并且計算這2r個奇數(shù)頂點之間的最短路及其長度;(2)在以這2r個頂點為新的頂點構(gòu)造完全圖H2r,在完全圖H2r中,頂點vi與vj之間的邊權(quán)重定義為圖G中vi與vj之間的最短路長度。,(3)在完全圖H2r上尋找權(quán)重最小的完美匹配M,每條匹配邊對應(yīng)于圖G中的一條最短路,把得到的r條最短路疊加到賦權(quán)圖G上,就得到新的賦權(quán)圖G*(這是一個歐拉圖);(4)對新的賦權(quán)圖G*,利用求歐拉回路的算法(Fleury)能夠找到一條歐拉回路C,這條回路C就是圖G上的中國郵遞員問題的最優(yōu)解(最優(yōu)路線)。,七、NP-完備的組合最優(yōu)化問題,7.1哈密爾頓問題(HamiltonianProblem)定義7.1設(shè)給定一個圖G=(V,E),C是一個圈,如果C經(jīng)過G的每個頂點恰好一次,則稱C是圖G的哈密爾頓圈,也稱圖G是哈密爾頓圖。問題7.1(哈密爾頓問題)對于給定圖G,問G是否含有哈密爾頓圈?即G是否是哈密爾頓圖?,7.2貨郎擔(dān)問題(TravellingSalesmanProblem)設(shè)給定一個賦權(quán)的完全圖G=(V,E;w),尋找G的一條閉回路C經(jīng)過所有的頂點(該回路C可以經(jīng)過某些頂點多次),使得閉回路C上邊的權(quán)重之和達到最小。一般地,貨郎擔(dān)問題沒有近似值為f(n)的近似算法,對于滿足三角不等式的完全圖G,存在近似值為2和3/2的近似算法(樹算法與Christofides算法)。,7.3排序問題(SchedulingProblem)給定m臺功能相同的機器,設(shè)有n件需要加工的任務(wù),其加工時間分別為p1,p2,…,pn,每件任務(wù)要不間斷地在某臺機器上加工完成,問:如何安排加工任務(wù)的順序(稱為方案),使得把全部任務(wù)加工完畢所需時間達到最小。存在近似值為2-1/m和4/3-1/3m的近似算法。,7.4裝箱問題(Bin-PackingProblem)給定n個大小分別為a1,a2,…,an的物品,把它們放入容量為1的多個箱子之中,要求每個箱子中所放數(shù)之和不超過該箱子的容量1,問:如何安排裝箱順序,使得需要的箱子數(shù)目盡可能少。該問題不存在近似值為3/2-k的近似算法,這里k是大于0的任意正數(shù)。存在多個近似算法來解決該問題,其近似值為2或3/2。,7.5背包問題(KnapsackProblem)給定一個背包,其容量為B,設(shè)有n件物品,每件物品的容量分別為a1,a2,…,an,當(dāng)把這些物品放入背包之中,產(chǎn)生的效益分別為p1,p2,…,pn,問:如何安排裝物體的順序(稱為方案),滿足裝入背包的物品容量之和不超過容量B,使得產(chǎn)生的效益之和達到最大。存在全多項式近似方案PTAS(polynomial-timeapprximationscheme)。,7.6最小點覆蓋問題設(shè)給定一個圖G=(V,E),尋找V的一個子集合S,使得G中每條邊的兩個頂點至少有一個要屬于S,稱S是圖G的一個點覆蓋。最小點覆蓋問題:就是要尋找點覆蓋S,使得|S|達到最小。存在近似值為2的近似算法來解決該問題(匹配、LP)。利用匹配算法,能夠解決二部圖的最小點覆蓋問題。,7.7染色問題給定圖G=(V,E),所謂G的一個k點染色是指把V劃分為k個子集V1,V2,…,Vk,使得集合Vi中的點染成顏色i,并且集合Vi是獨立集。點染色問題就是求這樣的最小正整數(shù)k。給定圖G=(V,E),所謂G的一個k邊染色是指把E劃分為k個子集1,E2,…,Ek,使得集合Ei中的邊染成顏色i,并且集合Ei是匹配。邊染色問題就是求這樣的最小正整數(shù)k。,7.8平面圖的面染色問題給定平面圖G=(V,E),所謂G的一個k面染色是指把G的所有面劃分為k個子集F1,F2,…,Fk,使得集合Fi中的面染成顏色i,任何有公共邊的兩個面具有不同的顏色。面染色問題就是求這樣的最小正整數(shù)k。四色猜想(定理):任何平面圖可以4-面染色。(1979)五色定理:任何平面圖可以5-面染色。(1890),謝謝!,- 1.請仔細閱讀文檔,確保文檔完整性,對于不預(yù)覽、不比對內(nèi)容而直接下載帶來的問題本站不予受理。
- 2.下載的文檔,不會出現(xiàn)我們的網(wǎng)址水印。
- 3、該文檔所得收入(下載+內(nèi)容+預(yù)覽)歸上傳者、原創(chuàng)作者;如果您是本文檔原作者,請點此認領(lǐng)!既往收益都歸您。
下載文檔到電腦,查找使用更方便
14.9 積分
下載 |
- 配套講稿:
如PPT文件的首頁顯示word圖標,表示該PPT已包含配套word講稿。雙擊word圖標可打開word文檔。
- 特殊限制:
部分文檔作品中含有的國旗、國徽等圖片,僅作為作品整體效果示例展示,禁止商用。設(shè)計者僅對作品中獨創(chuàng)性部分享有著作權(quán)。
- 關(guān) 鍵 詞:
- 云南大學(xué) 報告 問題 模型 算法
鏈接地址:http://m.wymoca.com/p-11516799.html