اعداد کاتالان – به زبان ساده

۴۳۵۱ بازدید
آخرین به‌روزرسانی: ۱۲ اردیبهشت ۱۴۰۲
زمان مطالعه: ۱۳ دقیقه
دانلود PDF مقاله
اعداد کاتالان – به زبان سادهاعداد کاتالان – به زبان ساده

«اعداد کاتالان» (Catalan Numbers) دنباله‌ای از اعداد صحیح مثبت هستند که در بسیاری از مسائل شمارش مبحث ترکیب ظاهر می‌شوند. این اعداد انواع خاصی از مسیرهای مشبک، درخت‌های باینری و بسیاری از اشیاء ترکیبی دیگر را شمارش می‌کنند. اعداد کاتالان در یک رابطه بازگشتی پایه صدق می‌کنند و یک فرمول بسته برحسب ضرایب دوجمله‌ای دارند.

997696

تعریف اعداد کاتالان

اعداد کاتالان C0C _ 0، C1C_ 1، ... ، CnC_ n و... از فرمول زیر به دست می‌آیند:

Cn=1n+1(2nn).\large C _ n = \frac { 1 } { n + 1 } \dbinom { 2 n } { n } .

چند عدد نخست از اعداد کاتالان به صورت زیر هستند:

C0=1C1=1C2=2C3=5C4=14C5=42.\large \begin {aligned} C _ 0 & = 1 \\ C _ 1 & = 1 \\ C _ 2 & = 2 \\ C _ 3 & = 5 \\ C _ 4 & = 1 4 \\ C _ 5 & = 4 2 . \end {aligned}

از این تعریف نمی‌توان بلافاصله فهمید که CnC _ nها اعدادی صحیح هستند، اما این امر از بسیاری از قضایای اثبات شده زیر پیروی خواهد کرد.

مسیرهای دایک و دنباله‌های پذیرفتنی

قضیه: تعداد عبارات پرانتز مجاز که شامل nn پرانتز راست و nn پرانتز چپ است، برابر با nnاُمین عدد کاتالان است. برای مثال، C3=5C _ 3 = 5 بوده و ۵ راه برای ایجاد عبارات معتبر با ۳ مجموعه از پرانتز‌ها وجود دارد:

  • ( ) ( ) ( )
  • ( ( ) ) ( )
  • ( ) ( ( ) )
  • ( ( ( ) ) )
  • ( ( ) ( ) )

با در نظر گرفتن پرانتزهای سمت راست به عنوان +1+ 1 و پرانتزهای سمت چپ به عنون 1- 1، می‌توانیم این‌گونه بنویسیم: اعداد دنباله a1a _ 1، a2a _ 2، ... و a2na _{ 2 n } متشکل از 2n2 n جمله را که می‌توان با استفاده از nn نسخه از +1+ 1ها و nn نسخه از 1- 1ها تشکیل داد، آن‌هایی هستند که در مجموع جزئی زیر صدق می‌کنند:

a1+a2++ak0\large a _ 1 + a _ 2 + \cdots + a _ k \ge 0

که در آن، k=1,2,3,,2nk = 1 , 2 , 3 , \ldots , 2 n برابر است با nnاُمین عدد کاتالان است.

اثبات: دنباله‌ای از nn نسخه از +1+ 1ها و nn نسخه از 1- 1ها را «پذیرفتنی» (Acceptable) گوییم اگر در شرط بالا صدق کند،‌ در غیر این صورت «نپذیرفتنی» (Unacceptable) است. تعداد دنباله‌های پذیرفتنی را با AnA_ n و تعداد دنباله‌های نپذیرفتنی را با UnU_ n مشخص می‌کنیم.

تعداد کل دنباله‌های +1+ 1 و 1- 1 را می‌توان به عنوان جابه‌جایی اشیایی از دو نوع مختلف با nn شیء از یک نوع و nn تا از نوع دیگر در نظر گرفت. بنابراین، تعداد کل چنین دنباله‌هایی برابر است با:

(2nn)=2n!n!n!.\large \dbinom { 2 n } { n } = \frac { 2 n ! } { n ! n ! } .

در نتیجه، An=(2nn)UnA _ n = \dbinom { 2 n } { n } - U _ n و گام بعدی شمارش UnU_ n است.

یک دنباله نپذیرفتنی از nn نسخه از +1+ 1ها و nn نسخه از 1-1ها را در نظر بگیرید. کوچک‌ترین عدد kk به گونه‌ای وجود دارد که مجموع جزئی a1+a2++aka _ 1 + a _ 2 + \cdots + a _ k منفی باشد. با توجه به کمینگی kk، باید تعدادِ برابرِ +1+ 1 و 1- 1 قبل از aka _ k وجود داشته باشد. بنابراین باید kk فرد بوده و رابطه a1+a2++ak1=0a _ 1 + a _ 2 + \cdots + a _ { k - 1 } = 0 و ak=1a _ k = -1 را داشته باشیم. در نتیجه، از بین جملات (a1,a2,...,ak)( a _ 1 , a _ 2 , . . . , a _ k ) تعداد k12\frac { k - 1 } { 2 } نسخه از +1+ 1 و k12+1=k+12\frac { k - 1 } { 2 } + 1 = \frac { k + 1 } { 2 } نسخه از 1- 1 وجود دارد. از بین جملات باقیمانده ak+1a _ { k + 1 }، ... و a2na _ { 2 n }، تعداد (nk12)\big ( n - \frac { k - 1 } { 2 } \big ) نسخه از +1+ 1 و (nk+12)\big ( n - \frac { k + 1 } { 2 } \big ) نسخه از 1- 1 وجود دارد.

حال، اثر معکوس کردن علامت هر یک از kk جمله اول، یعنی جایگزینی aia _ i با aia _ { - i } را برای i=1,2,...,ki = 1 , 2 , ... , k در نظر بگیرید. سایر جملات را تغییر نمی‌دهیم. اکنون این دنباله جدید به دست آمده و آن را b1b _ 1، b2b _ 2، b2b _ 2، b3b _ 3، ... و b2nb _ { 2 n } می‌نامیم که n+1n + 1 نسخه از +1+ 1ها و n1n - 1 نسخه از 1- 1ها دارد (زیرا به ۲ اضافه می‌شوند).

این موضوع، تابع ff را از مجموعه دنباله‌های نپذیرفتنی تا مجموعه دنباله‌هایی از ±1\pm 1 را که با ۲ جمع می‌شوند نتیجه می‌دهد. برای مشاهده یک به یک بودن تابع ff، معکوس آن را تشکیل می‌دهیم: فرض کنید B=b1,b2,,b2nB = b _ 1 , b _ 2 , \ldots , b _ { 2 n } دنباله‌ای از جملات ±1\pm 1ها باشد که با 2 جمع می‌شوند. فرض کنید kk اولین اندیس برای حالتی باشد که در b1,b2,,bkb _ 1 , b _ 2 , \ldots , b _ k تعداد +1+1 بیشتری نسبت به 1- 1ها وجود داشته باشد (باید چنین kkای وجود داشته باشد، زیرا مجموع همه جملات مثبت است). بنابراین g(B)g ( B ) را تعریف می‌کنیم که باید دنباله (نپذیرفتنی) b1,b2,,bk,bk+1,bk+2,,b2n- b _ 1 , - b _ 2 , \ldots , - b _ k , b _ { k + 1 } , b _ { k + 2 } , \ldots , b _ { 2 n } باشد. واضح است که ff و gg معکوس هم هستند.

اکنون تعداد دنباله‌های n+1n + 1 نسخه از +1+1ها و n1n - 1 نسخه از 1- 1ها برابر با 2n!(n+1)!(n1)!\frac { 2 n ! } { ( n + 1 ) ! ( n - 1 ) ! } است. با توجه به یک به یک بودن، همچنین، این تعداد برابر با تعداد دنباله‌های نپذیرفتنی نیز هست. بنابراین، تعداد کل دنباله‌های نپذیرفتنی به صورت زیر است:

Un=2n!(n+1)!(n1)!.\large U _ n = \frac { 2 n ! } { ( n + 1 ) ! ( n - 1 ) ! } .

در نتیجه، تعداد دنباله‌های پذیرفتنی برابر است با:

An=(2n)!n!n!Un=(2n)!n!n!(2n)!(n+1)!(n1)!=(2n)!n!(n1)!(1n1n+1)=(2n)!n!(n1)!1n(n+1)=1n+1(2n)!n!n!=Cn.\large \begin {aligned} A _ n & = \frac { ( 2 n ) ! } { n ! n ! } - U _ n \\ & = \frac { ( 2 n ) ! } { n ! n ! } - \frac { ( 2 n ) ! } { ( n + 1 ) ! ( n - 1 ) ! } \\ & = \frac { ( 2 n ) ! } { n ! ( n - 1 ) ! } \left ( \frac 1 { n } - \frac 1 { n + 1 } \right ) \\ & = \frac { ( 2 n ) ! } { n ! ( n - 1 ) ! } \frac1 { n ( n + 1 ) } \\ & = \frac 1 { n + 1 } \frac { ( 2 n ) ! } { n ! n ! } \\\\ & = C _ n . \end {aligned}

و اثبات کامل می‌شود.

نکته ۱: این دنباله‌ها همچنین «مسیرهای دایک» (Dyck Paths) به طول 2n2 n را توصیف می‌کنند که دنباله‌هایی از فواصل مساوی شمال شرقی و جنوب شرقی را می‌پیمایند که از مبداء آغاز شده و به محور xx ختم می‌شوند و هرگز زیر محور xx نمی‌روند. یک به یک بودن بين دنباله‌های پذیرفتنی و مسیرهای دایک، یک +1+ 1 را به حرکت شمال شرقی و یک 1- 1 به یک حرکت جنوب شرقی اختصاص می‌دهد. شرايط پذيرش، معادل مسیری است كه هرگز زير خط شروع و پايان نمی‌رود.

پنج مسیر دایک برای <span class=n=3n = 3" width="163" height="310">
پنج مسیر دایک برای n=3n = 3

نکته ۲: طبق آنچه گفتیم، می‌توان دریافت که اعداد کاتالان اعدادی صحیح هستند، اگرچه این موضوع از اتحاد Cn=(2nn)(2nn+1)C _ n = \binom { 2 n } { n } - \binom { 2 n } { n + 1 } نیز به دست می‌آید که از اثبات بالا آورده شده است.

رابطه بازگشتی و تابع مولد

یک ابزار مفید برای اثبات‌های مرتبط با اعداد کاتالان، رابطه بازگشتی توصیف کننده آن‌ها است.

قضیه: اعداد کاتالان در رابطه بازگشتی زیر صدق می‌کنند:

Cn+1=C0Cn+C1Cn1++CnC0=k=0nCkCnk.\large C _ { n + 1 } = C _ 0 C _ n + C _ 1 C _ { n - 1 } + \cdots + C _ n C _ 0 = \sum _ { k = 0 } ^ n C _ k C _ { n - k } .

اثبات: چند راه برای اثبات این قضیه وجود دارد، اما شاید زیرکانه‌ترینشان با مسیرهای دایک به طول 2(n+1)2 ( n + 1 ) باشد که در بالا Cn+1C _ { n + 1 } شمارش را دیدیم. برای یک مسیر دایک به طول 2(n+1)2 ( n + 1 )، فرض می‌کنیم 2(k+1)2 ( k + 1 ) اولین مختصات xx غیرصفر نخست باشد که در آن، مسیر به محور xx برخورد می‌کند و 0kn0\le k \le n.

مسیر به دو بخش می‌شکند، بخش چپ 2(k+1)2 ( k + 1 ) و بخش سمت راست آن. بخش راست یک مسیر دایک به طول 2(nk)2 ( n - k ) است، بنابراین، با CnkC _ { n - k } شمارش می‌شود. بخش چپ یک گام در جهت شمال شرقی است، سپس یک مسیر دایک به طول 2k2 k و آنگاه یک گام جنوب غربی طی می‌شود (مسیر میانی یک مسیر دایک است که هرگز به زیر نقطه شروع خود نمی‌رود، زیرا نمی‌تواند پیش از 2(k+1)2 ( k + 1 ) به محور xx برخورد کند). تعداد CkC_ k تا از این‌ها وجود دارد. بنابراین، در کل CkCnkC_ k C _ {n - k } مسیر وجود دارد که ابتدا در 2(k+1)2 ( k + 1 ) به محور xx برخورد می‌کنند و مجموع این جملات به Cn+1C _ { n + 1 } می‌رسد که یک رابطه بازگشتی است.

مثال: اگر n+1=3n + 1 = 3 باشد، آنگاه Cn+1C _ { n + 1 } پنج مسیر دایک شکل بالا را می‌شمارد:

  • مسیر 1 دارای k=2k = 2 است، و در C2C0C _ 2 C_ 0 شمارش شده است.
  • مسیر ۲ دارای k=2k = 2 است، و در C2C0C _ 2 C_ 0 شمارش شده است.
  • مسیر ۳ دارای k=1k = 1 است، و در C1C1C _ 1 C_ 1 شمارش شده است.
  • مسیر ۴ دارای k=0k = 0 است، و در C0C2C _ 0 C_ 2 شمارش شده است.
  • مسیر ۵ دارای k=0k = 0 است، و در C0C2C _ 0 C_ 2 شمارش شده است.

مسیر میانی به طول ۴ در مسیرهای ۱ و ۲، و نیمه پایینی قله چپ مسیر ۳، مسیرهای دایک در اثبات بالا هستند.

رابطه بازگشتی رابطه مفیدی است، زیرا می‌توان از آن برای اثبات این موضوع استفاده کرد که دنباله‌ای از اعداد، دنباله اعداد کاتالان است. اگر دنباله (آن را SnS_ n می‌نامیم) در رابطه بازگشتی مشابهی با اعداد کاتالان صدق کند و شرایط اولیه مشابه S0=1S_ 0 = 1 را داشته باشیم، آنگاه طبق استقرا تساوی Sn=CnS_ n = C_ n را داریم.

قضیه: تابع مولد اعداد کاتالان به صورت زیر است:

n=0Cnxn=114x2x=21+14x.\large \sum _ { n = 0 } ^ \infty C _ n x ^ n = \frac { 1 -\sqrt { 1 - 4 x } } { 2 x } = \frac 2 { 1 + \sqrt { 1 - 4 x } } .

اثبات: تابع f(x)=n=0Cnxnf ( x ) = \sum \limits _ { n = 0 } ^ \infty C _ n x ^ n را در نظر بگیرید. در نتیجه، می‌توان نوشت:

xf(x)2=n=0(C0Cn+C1Cn1++CnC0)xn+1=n=0Cn+1xn+1=f(x)1.\large \begin {aligned} x f ( x ) ^ 2 & = \sum _ { n = 0 } ^ \infty ( C _ 0 C _ n + C _ 1 C _ { n - 1 } + \cdots + C _ n C _ 0 ) x ^ { n + 1 } \\ & = \sum _ { n = 0 } ^ \infty C _ { n + 1 } x ^ { n + 1 } \\ & = f ( x ) - 1 . \end {aligned}

بنابراین، طبق فرمول، ریشه‌های f(x)=1±14x2xf ( x ) = \frac { 1 \pm \sqrt { 1 - 4 x } } { 2 x } را خواهیم داشت، اما علامت منفی تنها انتخاب است که معنی دارد، زیرا علامت مثبت منجر به عبارتی می‌شود که در x=0x = 0 تعریف نشده است (انتخاب علامت منفی به عبارتی می‌انجامد که یک حد x0x \to 0 دارد و طبق قاعده هوپیتال، داریم: limx0114x2x=limx02(14x)1/22=1\lim _ { x \to 0 } \frac { 1 - \sqrt { 1 - 4 x } } { 2 x } = \lim _ { x \to 0 } \frac { 2 ( 1 - 4 x ) ^ { - 1 / 2 } } 2 = 1.

سایر کاربردهای اعداد کاتالان

مثال: شخصی nn بلوک به شمال و nn بلوک به غرب از محل اقامتش حرکت می‌کند.

او هر روز 2n2 n بلوک برای حرکت دارد. اگر او هیچگاه از خط قطری خانه به دفتر کار عبور نکند، چه تعداد مسیر ممکن موجود دارد؟‌

اعداد کاتالان

پاسخ: واضح است که هر مسیر پذیرفتنی در بالا یا پایین خط قطری بوده و هر دوی این مسیرها متقارن هستند. بنابراین، تعداد مسیرهای زیر قطر را در ۲ ضرب می‌کنیم. هر مسیر دنباله‌ای از nn بلوک شمالی و nn بلوک غربی است. غرب را با +1+ 1 و شمال را با 1- 1 مشخص می‌کنیم. هر مسیر متناظر با دنباله a1a _ 1، a2a _ 2، ... و a2na _ { 2 n } از nn نسخه از +1+ 1ها و nn نسخه از 1- 1ها است. اما برای آنکه مسیر بالاتر از قطر نرود، باید برای k=1,2,,2nk = 1 , 2 , \ldots , 2 n، داشته باشیم:

a1+a2++ak0\large a _ 1 + a _ 2 + \cdots + a _ k \ge 0

بنابراین، تعداد مسیرهای پذیرفتنی بالای قطر برابر با nnاُمین عدد کاتالان است و کل تعداد مسیرهای پذیرفتنی برابر است با:

Cn=2(n+1)×(2n)!n!n!.\large C _ n = \frac { 2 } { ( n + 1 ) } \times \frac { ( 2 n ) ! } { n ! n ! } .

نمودار بالا مسیرهای زیر قطر را برای n=5n = 5 نشان می‌دهد. توجه کنید که تعداد چنین مسیرهایی برابر با C5=42C_ 5 = 42 است. بنابراین، جواب 2×42=842 \times 42 = 84 خواهد بود.

مثال: یک درخت باینری ریشه‌دار درختی است که یک گره ریشه دارد. گره ریشه گره‌ای است دارای صفر یا دو شاخه متصل به گره فرزند است. یک گره درونی یا داخلی است اگر دو گره داشته باشد که دو گره از آن آمده باشند. چه تعداد از درخت‌های باینری ریشه‌دار با nn گره داخلی وجود دارند؟

درخت‌های باینری ریشه‌دار با ۰، ۱، ۳ و ۳ ریشه داخلی.
درخت‌های باینری ریشه‌دار با ۰، ۱، ۲ و ۳ ریشه داخلی.

پاسخ: این موضوع یک توضیح خوب از اثبات این موضوع است که یک دنباله با استفاده از رابطه بازگشتی معادل با اعداد کاتالان است. فرض کنید RnR _ n تعداد درخت‌های ریشه‌دار باینری با nn گره داخلی باشد. در نتیجه، r0=R1=1r_ 0 = R_ 1 = 1 بوده که مطابق شکل بالا است. اکنون برای n0n \ge 0، فرض کنید یک درخت باینری ریشه‌دار با n+1n + 1 گره داخلی وجود داشته باشد. گره ریشه داخلی است. تعداد kk گره داخلی در چپ و nkn - k گره داخلی در راست وجود دارد. با نگاهی به سمت چپ و راست دو درخت باینری ریشه‌دار، به ترتیب، kk و nkn - k گره داخلی خواهیم داشت. در نتیجه، می‌توان نوشت:

Rn+1=k=0nRkRnk\large R _ { n + 1 } = \sum _ { k = 0 } ^ n R _ k R _ { n - k }

که مشابه رابطه بازگشتی مانند اعداد کاتالان است. بنابراین، برای همه‌ nnها، رابطه Rn=CnR_ n = C_n را داریم.

مثال: چند راه برای تقسیم یک n+2n + 2 ضلعی به nn مثلث وجود دارد (با رسم n1n - 1 خط غیرمتقاطع بین رئوس چندضلعی)؟

همه مثلث‌‌ها برای <span class=n=4n = 4." width="318" height="159">
همه مثلث‌‌ها برای n=4n = 4.

پاسخ: فرض کنید TnT_ n تعداد این مثلث‌‌ها باشد و T0=1T_ 0 = 1 را تعریف می‌کنیم. Tn+1T_ {n+1} را چیزی در نظر می‌گیریم که یک (n+3)( n + 3 ) ضلعی را می‌شمارد و مثلث‌سازی‌ها را دسته‌بندی می‌کند.

رئوس را v1v _ 1، v2v _ 2، ... و vn+3v _ { n + 3 } نامگذاری می‌کنیم. فرض کنید یال v1v2v _ 1 v _ 2 باشد. اگر مثلث این لبه به پایان برسد، v1v2vkv _ 1 v _ 2 v _ k را خواهیم داشت، آنگاه این مثلث چندضلعی را به دو چندضلعی باقیمانده تقسیم می‌کند که باید مثلث شده باشد.

  • اگر k=3k = 3 باشد، آنگاه آنچه در سمت چپ است، یک n+2n + 2ضلعی است. تعداد سه‌گوش‌ها مشابه این T0TnT_0 T_ n است.
  • اگر k=4k = 4 باشد، یک مثلث v2v3v4v _ 2 v _ 3 v _ 4 روی یک ضلع است و یک (n+1)( n + 1 ) ضلعی روی ضلع دیگر است. تعداد سه‌گوش‌ها مانند این T1Tn1T_ 1 T_ { n - 1 } است.
  • اگر k=5k = 5 باشد، یک چهارگوش v2v3v4v5v _ 2 v _ 3 v _ 4 v _ 5 روی یک ضلع است و یک nnضلعی روی ضلع دیگر است. تعداد سه‌گوش‌های مشابه این، T2Tn2T_ 2 T _ { n - 2 } است.

با ادامه به همین صورت، خواهیم داشت:

Tn+1=T0Tn+T1Tn1++TnT0.\large T _ { n + 1 } = T _ 0 T _ n + T _ 1 T _ { n - 1 } + \cdots + T _ n T _ 0 .

همچنین T0=1T_ 0 = 1.

این همان رابطه بازگشتی و شرایط اولیه است که اعداد کاتالان را برآورده می‌کند، بنابراین باید برای هر nn، داشته باشیم: Tn=CnT_ n = C_ n.

بر اساس رای ۱۸ نفر
آیا این مطلب برای شما مفید بود؟
اگر بازخوردی درباره این مطلب دارید یا پرسشی دارید که بدون پاسخ مانده است، آن را از طریق بخش نظرات مطرح کنید.
منابع:
Brilliant
دانلود PDF مقاله
نظر شما چیست؟

نشانی ایمیل شما منتشر نخواهد شد. بخش‌های موردنیاز علامت‌گذاری شده‌اند *