卡特蘭數及其應用

卡特蘭數

      Catalan number,卡特蘭數又稱卡塔蘭數,是組合數學中一個常出現在各種計數問題中出現的數列。以比利時的數學家歐仁·查理·卡塔蘭 (1814–1894)命名。
       令h(0)=1,h(1)=1,catalan數滿足遞推式:h(n)= h(0)*h(n-1)+h(1)*h(n-2) + ... + h(n-1)h(0) (n>=2)
        catalan數公式的一般是形式爲:
                                                         C_n = \frac{1}{n+1}{2n \choose n} = \frac{(2n)!}{(n+1)!n!}
遞推關係:
C_0 = 1 \quad \mbox{and} \quad C_{n+1}=\sum_{i=0}^{n}C_i\,C_{n-i}\quad\mbox{for }n\ge 0.

   它也滿足

C_0 = 1 \quad \mbox{and} \quad C_{n+1}=\frac{2(2n+1)}{n+2}C_n, 這提供了一個更快速的方法來計算卡塔蘭數。

卡特蘭數的應用

  • n個元素順序入棧,出棧順序有多少種
        此問題是一個卡特蘭數問題,證明過程如下:

     令1表示進棧,0表示出棧,則可轉化爲求一個2n位、含n個1、n個0的二進制數,滿足從左往右掃描到任意一位時,經過的0數不多於1數。顯然含n個1、n個0的2n位二進制數共有{2n \choose n}個,下面考慮不滿足要求的數目。

    考慮一個含n個1、n個0的2n位二進制數,掃描到第2m+1位上時有m+1個0和m個1(容易證明一定存在這樣的情況),則後面的0-1排列中必有n-m個1和n-m-1個0。將2m+2及其以後的部分0變成1、1變成0,則對應一個n+1個0和n-1個1的二進制數。

    反過來,任何一個由n+1個0和n-1個1組成的2n位二進制數,由於0的個數多2個,2n爲偶數,故必在某一個奇數位上出現0的累計數超過1的累計數。同樣在後面部分0和1互換,使之成爲由n個0和n個1組成的2n位數,即n+1個0和n-1個1組成的2n位數必對應一個不符合要求的數。
     因而不合要求的2n位數與n+1個0,n-1個1組成的排列一一對應。 顯然,不符合要求的方案數爲c(2n,n+1)。

     從而C_n = {2n \choose n} - {2n \choose n + 1} = \frac{1}{n+1}{2n \choose n}。證畢。

  • 括號化問題
   如,矩陣鏈乘: P=a1×a2×a3×……×an,依據乘法結合律,不改變其順序,只用括號表示成對的乘積,試問有幾種括號化的方案?(h(n)種)

  • 出棧次序問題
  1、一個棧(無窮大)的進棧序列爲1,2,3,..n,有多少個不同的出棧序列?
  2、有2n個人排成一行進入劇場。入場費5元。其中只有n個人有一張5元鈔票,另外n人只有10元鈔票,劇院無其它鈔票,問有多少中方法使得只要有10元的人買票,售票處就有5元的鈔票找零?(將持5元者到達視作將5元入棧,持10元者到達視作使棧中某5元出棧)。
  • 將多邊行劃分爲三角形問題
  1、將一個凸多邊形區域分成三角形區域的方法數?
  2、一位大城市的律師在她住所以北n個街區和以東n個街區處工作。每天她走2n個街區去上班。如果她從不穿越(但可以碰到)從家到辦公室的對角線,那麼有多少條可能的道路?
    3、在圓上選擇2n個點,將這些點成對連接起來使得所得到的n條線段不相交的方法數?

  • 給頂節點組成二叉樹的問題
  給定N個節點,能構成多少種不同的二叉樹?

一些筆試題

1、16個人按順序去買燒餅,其中8個人每人身上只有一張5塊錢,另外8個人每人身上只有一張10塊錢。燒餅5塊一個,開始時燒餅店老闆身上沒有錢。16個顧客互相不通氣,每人只買一個。問這16個人共有多少種排列方法能避免找不開錢的情況出現。

h(8)=16!/(8!*9!)=1430,所以總數=h(8)*8!*8!=16!/9

2、在圖書館一共6個人在排隊,3個還《面試寶典》一書,3個在借《面試寶典》一書,圖書館此時沒有了面試寶典了,求他們排隊的總數?

h(3)=6!/(3!*4!)=5,所以總數=h(3)*3!*3!=180


發佈了26 篇原創文章 · 獲贊 9 · 訪問量 24萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章