قضیه اصلی واکاوی الگوریتمها
قضیه اصلی واکاوی (تحلیل) الگوریتمها که حالتی خاص از قضیهٔ اکرا-بازی است در تحلیل الگوریتمها، یک راه حل سرراست برای حالتهای مجانبی که در عمل در انواع روابط بازگشتی رخ میدهند، ارائه میکند. این قضیه با کتاب درسی معروف مقدمهای بر الگوریتمها نوشتهٔ کرمن، لیسرسن، ریوست و استین به شهرت رسید. این قضیه در بخش ۴٫۳ دراین کتاب معرفی شدهاست و متعاقباً در بخش ۴٫۴ به اثبات رسیدهاست. هرچند که نمیتوان تمامی روابط بازگشتی را به کمک قضیهٔ اصلی حل کرد.
محتویات |
شکل کلی[ویرایش]
قضیهٔ اصلی روابطی را مورد بررسی قرار میدهد که به شکل زیر باشند:

در استفاده از رابطهٔ فوق برای یک الگوریتم بازگشتی معنای علائم به کار رفته، به شرح زیر است: *n اندازهٔ مسألهاست.
- a تعداد زیرمسأله هاست.
- n/b اندازهٔ هر یک از زیرمسأله هاست. (در اینجا فرض شدهاست که اندازهٔ همهٔ زیرمسألهها با هم برابر است.)
- (f(n هزینهٔ بخش غیر بازگشتی است که شامل هزینهٔ تقسیم مسأله به زیرمسألهها و هزینهٔ ادغام پاسخ به زیرمسأله هاست.
در سه حالت میتوان یک حد مجانبی مشخص کرد:
حالت ۱[ویرایش]
شکل کلی[ویرایش]
اگر ثابت
وجود داشته باشد به طوری که رابطهٔ
برقرار باشد،
آن گاه داریم:

مثال[ویرایش]

همان طور که در فرمول فوق دیده میشود، متغیرها دارای مقادیر زیر هستند:
,
,
, 
حال باید برقراری معادلهٔ زیر را بررسی کنیم:

اگر مقادیر متغیرها را در این رابطه جایگزین کنیم، خواهیم داشت:

با انتخاب
داریم:

از آن جایی که معادلهٔ بالا برقرار است، حالت اول قضیهٔ اصلی را برای رابطهٔ بازگشنی به کار میبریم و از نتیجهٔ زیر استفاده میکنیم:

اگر مقادیر فوق را در رابطهٔ بالا قرار دهیم، در نهایت خواهیم داشت:

از این رو رابطهٔ بازگشتی داده شده (T(n از(Θ(n³ است.
(راه حل دقیق رابطهٔ بازگشتی نیز این نتیجه را تأیید میکند، که در آن
، بافرض
است.)
حالت ۲[ویرایش]
شکل کلی[ویرایش]
اگر داشته باشیم:

آن گاه خواهیم داشت:

مثال[ویرایش]

همان طور که در فرمول فوق مشاهده میشود، متغیرها مقادیر زیر را اختیار میکنند:
,
,
,
, 
حال میبایست برقراری رابطهٔ زیر را بررسی کنیم (در حالتی که k=۰ باشد):

اگر مفادیر متغیرها را از رابطهٔ بالا در این رابطه جایگزین کنیم، خواهیم داشت:

از آن جایی که این رابطه برقرار است، حالت دوم قضیهٔ اصلی را برای رابطهٔ بازگشنی به کار میبریم و از نتیجهٔ زیر استفاده میکنیم:

با جایگزین کردن مقادیر فوق در این رابطه در نهایت خواهیم داشت:

از این رو رابطهٔ بازگشتی داده شدهٔ (T(n از (Θ(n log n است.
(راه حل دقیق رابطهٔ بازگشتی نیز این نتیجه را تأیید میکند، که در آن
، بافرض
است.)
حالت ۳[ویرایش]
شکل کلی[ویرایش]
اگر ثابت
وجود داشته باشد به طوری که رابطهٔ
برقرار باشد و هم چنین اگر برای nهای به اندازهٔ کافی بزرگ ثابت
وجود داشته باشد به گونهای که رابطه زیر برقرار باشد:

آنگاه خواهیم داشت:

مثال[ویرایش]

همان طور که در فرمول فوق دیده میشود، متغیرها مقادیر زیر را اختیار میکنند:
,
,
, 
حال میبایست برقراری معادلهٔ زیر را مورد بررسی قرار دهیم:

اگر مقادیر متغیرها را طبق روابط بالا قرار دهیم و مقدار
را انتخاب کنیم، خواهیم داشت:

از آن جایی که معادلهٔ فوق برقرار است، حال باید شرط دوم را مورد بررسی قرار دهیم. به عبارت دیگر باید درستی رابطهٔ زیر را مورد بررسی قرار دهیم:

اگر بار دیگر مقادیر متغیرها را طبق روابط بالا قرار دهیم، خواهیم داشت:

اگر
را برگزینیم، آن گاه:

پس خواهیم داشت:

اگر بار دیگر مقادیر لازم را قرار دهیم، رابطهٔ زیر به دست میآید:

از این رو رابطهٔ بازگشتی داده شده (T(n از (Θ(n² است.
(راه حل دقیق رابطهٔ بازگشتی نیز این نتیجه را تأیید میکند، که در آن
، بافرض
است.)
حالتهای غیر قابل قبول[ویرایش]
معادلات زیر را نمیتوان با استفاده از قضیهٔ اصلی حل کرد:

a مقدار ثابت نیست.

اختلاف بین (f(n و
غیر چندجملهای است.

a<۱ است درحالی که نمیتوان کم تر از یک زیر مسأله داشت.
:
(f(n مثبت نیست.
جستارهای وابسته[ویرایش]
منابع[ویرایش]
- Thomas H. Cormen, Charles E. Leiserson, Ronald L. Rivest, and Clifford Stein. Introduction to Algorithms, Second Edition. MIT Press and McGraw-Hill, 2001. ISBN 0-262-03293-7.
- Michael T. Goodrich and Roberto Tamassia. Algorithm Design: Foundation, Analysis, and Internet Examples. Wiley, 2002. ISBN 0-471-38365-1. The master theorem (including the version of Case 2 included here, which is stronger than the one from CLRS) is on pp. 268–270.
- مشارکتکنندگان ویکیپدیا، «Master theorem»، ویکیپدیای انگلیسی، دانشنامهٔ آزاد (بازیابی در ۳ می ۲۰۱۱).