1. 程式人生 > >五大常用演算法之分支定界法

五大常用演算法之分支定界法

看了五大常用演算法之一這篇博文,感覺理解了很多,可是純粹都是理論,缺少一些示例,所以準備綜合一篇博文,以幫助自己記憶,原文:

http://www.cnblogs.com/steven_oyj/archive/2010/05/22/1741378.html

一、基本描述

    類似於回溯法,也是一種在問題的解空間樹T上搜索問題解的演算法。但在一般情況下,分支限界法與回溯法的求解目標不同。回溯法的求解目標是找出T中滿足約束條件的所有解,而分支限界法的求解目標則是找出滿足約束條件的一個解,或是在滿足約束條件的解中找出使某一目標函式值達到極大或極小的解,即在某種意義下的最優解

   (1)分支搜尋演算法

    所謂“分支”就是採用廣度優先的策略,依次搜尋E-結點的所有分支,也就是所有相鄰結點,拋棄不滿足約束條件的結點,其餘結點加入活結點表。然後從表中選擇一個結點作為下一個E-結點,繼續搜尋。

     選擇下一個E-結點的方式不同,則會有幾種不同的分支搜尋方式。

   1)FIFO搜尋

   2)LIFO搜尋

   3)優先佇列式搜尋

(2)分支限界搜尋演算法 

二、分支限界法的一般過程

    由於求解目標不同,導致分支限界法與回溯法在解空間樹T上的搜尋方式也不相同。回溯法以深度優先的方式搜尋解空間樹T,而分支限界法則以廣度優先或以最小耗費優先的方式搜尋解空間樹T

    分支限界法的搜尋策略是:在擴充套件結點處,先生成其所有的兒子結點(分支),然後再從當前的活結點表中選擇下一個擴充套件對點。為了有效地選擇下一擴充套件結點,以加速搜尋的程序,在每一活結點處,計算一個函式值(限界),並根據這些已計算出的函式值,從當前活結點表中選擇一個最有利的結點作為擴充套件結點,使搜尋朝著解空間樹上有最優解的分支推進,以便儘快地找出一個最優解。

    分支限界法常以廣度優先或以最小耗費(最大效益)優先的方式搜尋問題的解空間樹。問題的解空間樹是表示問題解空間的一棵有序樹,常見的有子集樹和排列樹。在搜尋問題的解空間樹時,分支限界法與回溯法對當前擴充套件結點所使用的擴充套件方式不同。在分支限界法中,每一個活結點只有一次機會成為擴充套件結點。活結點一旦成為擴充套件結點,就一次性產生其所有兒子結點。在這些兒子結點中,那些導致不可行解或導致非最優解的兒子結點被捨棄,其餘兒子結點被子加入活結點表中。此後,從活結點表中取下一結點成為當前擴充套件結點,並重覆上述結點擴充套件過程。這個過程一直持續到找到所求的解或活結點表為空時為止。

三、回溯法和分支限界法的一些區別

    有一些問題其實無論用回溯法還是分支限界法都可以得到很好的解決,但是另外一些則不然。也許我們需要具體一些的分析——到底何時使用分支限界而何時使用回溯呢?

回溯法和分支限界法的一些區別:

   方法對解空間樹的搜尋方式       儲存結點的常用資料結構      結點儲存特性常用應用

  回溯法深度優先搜尋堆疊活結點的所有可行子結點被遍歷後才被從棧中彈出找出滿足約束條件的所有解

  分支限界法廣度優先或最小消耗優先搜尋隊列、優先佇列每個結點只有一次成為活結點的機會找出滿足約束條件的一個解或特定意義下的最優解


其他更好的解釋:

分支定界 (branch and bound) 演算法是一種在問題的解空間樹上搜索問題的解的方法。但與回溯演算法不同,分支定界演算法採用廣度優先或最小耗費優先的方法搜尋解空間樹,並且,在分支定界演算法中,每一個活結點只有一次機會成為擴充套件結點。

利用分支定界演算法對問題的解空間樹進行搜尋,它的搜尋策略是:

1 .產生當前擴充套件結點的所有孩子結點;

2 .在產生的孩子結點中,拋棄那些不可能產生可行解(或最優解)的結點;

3 .將其餘的孩子結點加入活結點表;

4 .從活結點表中選擇下一個活結點作為新的擴充套件結點。

如此迴圈,直到找到問題的可行解(最優解)或活結點表為空。

從活結點表中選擇下一個活結點作為新的擴充套件結點,根據選擇方式的不同,分支定界演算法通常可以分為兩種形式:

1 . FIFO(First In First Out) 分支定界演算法:按照先進先出原則選擇下一個活結點作為擴充套件結點,即從活結點表中取出結點的順序與加入結點的順序相同。

2 .最小耗費或最大收益分支定界演算法:在這種情況下,每個結點都有一個耗費或收益。假如要查詢一個具有最小耗費的解,那麼要選擇的下一個擴充套件結點就是活結點表中具有最小耗費的活結點;假如要查詢一個具有最大收益的解,那麼要選擇的下一個擴充套件結點就是活結點表中具有最大收益的活結點。

FIFO分支定界演算法

因為沒有一個感覺好的說明,固貼上兩個網址上的演算法,有興趣可以看一看。

FIFO分支定界演算法初探

http://www.21shipin.com/html/62062.shtml

http://www.cppblog.com/ivenher/articles/1777.html