算法設(shè)計(jì)與分析課程設(shè)計(jì)報(bào)告——穩(wěn)定婚姻問題的gale-shapley算法_第1頁(yè)
已閱讀1頁(yè),還剩9頁(yè)未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

1、<p>  算法設(shè)計(jì)與分析課程設(shè)計(jì)</p><p>  題目:模擬實(shí)現(xiàn)穩(wěn)定婚姻問題的Gale-Shapley算法</p><p><b>  設(shè)計(jì)分析測(cè)試報(bào)告</b></p><p>  2013年1月 12日</p><p><b>  程序算法設(shè)計(jì)說明書</b></p>

2、<p><b>  前言</b></p><p>  1.問題描述:穩(wěn)定婚姻問題:有n男n女,每人都按他對(duì)(異性)對(duì)象的喜好程度按1至n排列。安排男女結(jié)婚,使得下列情形為真:在n男n女中的任意兩對(duì)夫婦(M, W)和(m, w),都不存在M男對(duì)w女喜好度大于現(xiàn)任妻子W女,并且w女對(duì)M男喜好度也大于現(xiàn)任丈夫m男的情形發(fā)生,此種情形稱為不穩(wěn)定。</p><p> 

3、 2.程序編制環(huán)境相關(guān)說明:</p><p>  系統(tǒng):WINDOWS 7</p><p>  編制環(huán)境:visual studio 8</p><p>  程序主要算法設(shè)計(jì)分析說明</p><p>  Gale-Shapley算法的基本思想如下:</p><p>  (1)初始,每個(gè)人都是未婚的。假設(shè)一個(gè)未婚的男人m

4、選擇了他的優(yōu)先表上排名最高的女人w,并且向她求婚。能立刻聲明(m, w)將是最后的穩(wěn)定匹配中的一對(duì)嗎?不一定:因?yàn)樵趯淼哪硞€(gè)時(shí)候,女人w偏愛的男人m,可能向她求婚。另一方面,對(duì)w來說,立刻拒絕m可能是危險(xiǎn)的,她可能沒有接收到來自她的優(yōu)先表上排名像m那樣高的某個(gè)人的求婚。于是一種自然地想法是使這個(gè)(m, w)對(duì)進(jìn)入一種中間狀態(tài)一約會(huì)。</p><p>  (2)假設(shè)我們現(xiàn)在處在某種狀態(tài),某些男人和女人是自由的(沒

5、有約會(huì)),某些是有約會(huì)的。任意一個(gè)自由的男人m選擇他還沒有求過婚的最高排名的女人w,且向她求婚。如果w也是自由的,那么m和w就成為約會(huì)狀態(tài)。否則,w已經(jīng)在與某個(gè)其他的男人m,約會(huì)。在這種情況下,她來決定m和m,哪 個(gè)人在她的優(yōu)先表中的排名更高;排名更高的男人變成與w約會(huì)而另一個(gè)人變成自由的。</p><p>  (3)最后,當(dāng)沒有一個(gè)人是自由的時(shí)候,算法將結(jié)束;此刻所有的約會(huì)將被宣告為最后的結(jié)果,且將返回最終的完

6、美匹配。</p><p>  所以,在N對(duì)男女中,男生采用主動(dòng)出擊追求自己最喜歡的女生策略,女生采用“守株待兔”和“喜新厭舊”策略。每一位男生主動(dòng)去追求自己最喜歡的女生,而女生則在追求自己的男生中與現(xiàn)任男友中,選擇一位最喜歡的接受。如果追求成功,為被拋棄的男友追求他下一位喜歡的女生。如果追求不成功,則為這位男生追求他下一位喜歡的女生。這樣進(jìn)行了N次循環(huán)后,每一位男生都是從自己最喜歡的女生開始追求,并且都有女友,那

7、么男生喜歡的程度多于現(xiàn)任妻子的那位女生肯定是曾經(jīng)拒絕過自己的。同理,女生也是按照自己喜歡程度進(jìn)行選擇的。那么也不會(huì)出現(xiàn)不穩(wěn)定問題。</p><p><b>  程序模塊說明</b></p><p><b>  總體設(shè)計(jì)說明:</b></p><p>  程序采用兩個(gè)二維數(shù)組man[max][max],woman[max][

8、max]來記錄max位男生,女生對(duì)異性的喜歡程度順序。</p><p>  數(shù)組acman[]記錄男生下一位追求的女生順序(最開始從0位,也就是最喜歡的一位開始);</p><p>  數(shù)組acwoman[]記錄每一位女生當(dāng)前男友(最開始設(shè)置一位虛擬男友,其喜歡程度最小)</p><p>  采用4個(gè)for循環(huán),分別對(duì)4個(gè)數(shù)組初始化。</p><

9、p>  采用一個(gè)for循環(huán)遍歷man數(shù)組(為每一位男生追求其最喜歡的女生)</p><p>  采用一個(gè)for循環(huán)輸出結(jié)果</p><p><b>  模塊說明:</b></p><p>  模塊一:bool changeBF(vector<vector<int>> woman,int i,int newBF,in

10、t oldBF,int max)函數(shù)</p><p>  概要說明:判斷某位女生的當(dāng)前男友與追求她的男友的排位順序(喜歡程度)</p><p>  關(guān)鍵數(shù)據(jù)結(jié)構(gòu)和算法及其分析(比較newBF和oldBF在數(shù)組woman[][max]的序號(hào)大小,從而判斷喜歡程度)</p><p>  輸入(數(shù)組woman[][])</p><p>  輸出(b

11、ool類型1,0)</p><p>  總結(jié)(含主函數(shù)設(shè)計(jì)說明)</p><p>  穩(wěn)定婚姻問題被應(yīng)用到許多實(shí)際問題的處理過程中,例如學(xué)生的入學(xué),工作招聘,醫(yī)生和醫(yī)院進(jìn)行匹配等等.雖然穩(wěn)定婚姻問題是一個(gè)NP問題,但是為找到所有的穩(wěn)定匹配結(jié)果,我們?cè)O(shè)計(jì)了基于先序遍歷森林的算法,利用此算法,對(duì)于眾多不同的婚姻匹配,不會(huì)重復(fù)判斷它們包含相同的配對(duì)子部分,這樣大大節(jié)省了時(shí)間。為了進(jìn)一步提高速度,

12、由Gale-Shapley算法的性質(zhì)得到一個(gè)定律及其推論,利用推論對(duì)算法做了進(jìn)一步改進(jìn),減少了時(shí)間復(fù)雜度。</p><p>  課程設(shè)計(jì)是一項(xiàng)復(fù)雜的工作,在程序設(shè)計(jì)的過程中,許多我們認(rèn)為應(yīng)該是正確的代碼,往往不能運(yùn)行我們想要的結(jié)果。這就需要我們的耐心與細(xì)心,去糾正任何一個(gè)可能的細(xì)小錯(cuò)誤。此次算法課程設(shè)計(jì),我將所學(xué)到的知識(shí)運(yùn)用到了實(shí)踐中,雖然在設(shè)計(jì)過程中遇到很大的困難,一開始的時(shí)候并不知道穩(wěn)定婚姻問題的算法思想,但

13、是在老師和同學(xué)的幫助下,我理解了Gale-Shapley算法的思想。在數(shù)據(jù)結(jié)構(gòu)實(shí)現(xiàn)的過程中,我試過用結(jié)構(gòu)體,鏈表等數(shù)據(jù)結(jié)構(gòu),最后還是覺得直接用數(shù)組最簡(jiǎn)潔。確定了用二維數(shù)組,程序就基本定下來了,主函數(shù)就是對(duì)二維數(shù)組的遍歷。為了實(shí)現(xiàn)多樣化,我在對(duì)二維數(shù)組初始化時(shí)采用了由用戶輸入實(shí)現(xiàn)初始化。這里用到了動(dòng)態(tài)數(shù)組的知識(shí)。在整個(gè)實(shí)驗(yàn)的過程中,遇到不少困難,但是最終得以克服,并且最終獲得了成功。</p><p>  經(jīng)歷這次課

14、程設(shè)計(jì),我深深體會(huì)到算法的神奇,我們要編寫一段代碼,首先要有一種算法思路,這是至關(guān)重要的,甚至可以成為編程的靈魂,但是算法思想比較難以想到,這就需要我們?cè)谝院蟮膶?shí)踐中經(jīng)常鍛煉,經(jīng)常思考,培養(yǎng)自己思考能力,這樣才能不斷進(jìn)步。</p><p><b>  五、參考文獻(xiàn)</b></p><p>  清華大學(xué)出版社《算法設(shè)計(jì)與分析》</p><p>&

15、lt;b>  程序及算法測(cè)試報(bào)告</b></p><p><b>  前言</b></p><p>  測(cè)試目的及采用的主要測(cè)試方法</p><p>  目的:測(cè)試該程序能否成功對(duì)N對(duì)男女成功配對(duì),且婚姻穩(wěn)定。</p><p>  測(cè)試方法:設(shè)置不同的數(shù)據(jù),判斷是否有錯(cuò)誤。</p><

16、;p>  被測(cè)試程序算法說明及流程圖等</p><p><b>  代碼:</b></p><p>  #include<iostream></p><p>  #include <vector> </p><p>  using namespace std;</p>&l

17、t;p>  void main()</p><p><b>  {</b></p><p>  int newBF;</p><p>  int oldBF;</p><p><b>  int t;</b></p><p>  int search;</p>

18、;<p><b>  int max;</b></p><p>  cout<<"輸入男生人數(shù)(女生):"<<endl;</p><p><b>  cin>>max;</b></p><p>  int *nextm=new int[max+1

19、]; //男生下個(gè)追求女士的號(hào)碼</p><p>  int *nextw=new int[max+1];//女士接受的男生號(hào)</p><p>  vector<vector<int> > man(max, vector<int>(max));//男生對(duì)女士的喜歡程度順序</p><p>  vector&l

20、t;vector<int> > woman(max, vector<int>(max+1));//女生對(duì)男生的喜歡程度順序</p><p>  for(int i=0;i<max+1;i++)</p><p>  nextm[i]=0;</p><p>  for(int i=0;i<max;i++)</

21、p><p>  nextw[i]=max;//對(duì)數(shù)組初始化</p><p>  for(int i=0;i<max;i++)</p><p><b>  {</b></p><p>  cout<<"第"<<i<<"位男士喜歡女生順序?yàn)椋?quot;&l

22、t;<endl;</p><p>  for(int j=0;j<max;j++)</p><p>  cin>>man[i][j];</p><p><b>  }</b></p><p>  for(int i=0;i<max;i++)</p><p><b

23、>  {</b></p><p>  cout<<"第"<<i<<"位女士喜歡男生順序?yàn)椋?quot;<<endl;</p><p>  for(int j=0;j<max;j++)</p><p>  cin>>woman[i][j];</p&g

24、t;<p>  woman[i][max]=max;</p><p><b>  }</b></p><p>  bool changeBF(vector<vector<int> > woman,int,int,int,int);</p><p>  for(int j=0;j<max;j++)&

25、lt;/p><p><b>  {</b></p><p>  t=man[j][nextm[j]];//要追求的女生號(hào)</p><p>  if(nextw[t]==j)</p><p><b>  {//什么也不做</b></p><p><b>  }</b

26、></p><p><b>  else </b></p><p><b>  {</b></p><p><b>  newBF=j;</b></p><p>  oldBF=nextw[t];</p><p>  if(changeBF(wom

27、an,t,newBF,oldBF,max))</p><p><b>  {</b></p><p>  nextm[oldBF]++;</p><p>  nextw[t]=newBF;</p><p>  if(oldBF>j)</p><p><b>  {</b>

28、;</p><p><b>  //什么也不做</b></p><p><b>  }</b></p><p><b>  else</b></p><p><b>  {</b></p><p>  j=oldBF;//前任男友

29、被拋棄,且號(hào)碼小,應(yīng)讓其重新最求女生</p><p><b>  j--;</b></p><p><b>  }</b></p><p><b>  }</b></p><p><b>  else</b></p><p><

30、;b>  {</b></p><p>  nextm[j]++;//最求不成功,繼續(xù)追求下一位喜歡的女生</p><p><b>  j--;</b></p><p><b>  }</b></p><p><b>  }</b></p><

31、;p><b>  }</b></p><p>  for(int j=0;j<max;j++)</p><p><b>  {</b></p><p>  cout<<"第"<<j<<"位男士"<<"的女友是&qu

32、ot;<<man[j][nextm[j]]<<endl;</p><p><b>  }</b></p><p><b>  }</b></p><p>  bool changeBF(vector<vector<int> > woman,int i,int newBF,

33、int oldBF,int max)</p><p><b>  {</b></p><p>  int temp1;</p><p>  int temp2;</p><p>  for(int j=0;j<=max;j++)</p><p><b>  {</b>&

34、lt;/p><p>  if(woman[i][j]==newBF)</p><p><b>  {</b></p><p><b>  temp1=j;</b></p><p><b>  break;</b></p><p><b>  }&l

35、t;/b></p><p><b>  }</b></p><p>  for(int j=0;j<=max;j++)</p><p><b>  {</b></p><p>  if(woman[i][j]==oldBF)</p><p><b>  

36、{</b></p><p><b>  temp2=j;</b></p><p><b>  break;</b></p><p><b>  }</b></p><p><b>  }</b></p><p>  re

37、turn(temp1<temp2);//比較前任與現(xiàn)任的排序先后</p><p><b>  }</b></p><p><b>  測(cè)試環(huán)境說明</b></p><p>  系統(tǒng):WINDOWS 7</p><p>  測(cè)試環(huán)境:visual studio 8</p><

38、p><b>  測(cè)試用例說明</b></p><p><b>  測(cè)試用例1</b></p><p>  目的:判斷是否一對(duì)一的配對(duì)</p><p><b>  輸入</b></p><p>  預(yù)期輸出:不會(huì)出現(xiàn)重復(fù)數(shù)字</p><p><

39、b>  實(shí)際輸出</b></p><p>  測(cè)試結(jié)果:顯示每一位男生都唯一配對(duì)以為女生</p><p><b>  測(cè)試用例2</b></p><p>  目的:測(cè)試每一位配對(duì)的組合是否婚姻穩(wěn)定</p><p><b>  輸入</b></p><p> 

40、 預(yù)期輸出:0 3 2 1</p><p><b>  實(shí)際輸出</b></p><p>  測(cè)試結(jié)果:配對(duì)婚姻穩(wěn)定</p><p><b>  3.測(cè)試用例3</b></p><p>  目的:繼續(xù)測(cè)試每一對(duì)情侶婚姻是否穩(wěn)定</p><p><b>  輸入<

41、;/b></p><p>  預(yù)期輸出:1 0 2</p><p><b>  實(shí)際輸出</b></p><p>  測(cè)試結(jié)果:配對(duì)婚姻穩(wěn)定</p><p><b>  測(cè)試結(jié)果分析</b></p><p>  測(cè)試結(jié)果顯示,每一位男生其配對(duì)的女生都是唯一的;每一位情侶

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 眾賞文庫(kù)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

評(píng)論

0/150

提交評(píng)論