قضیه اصلی (تحلیل الگوریتم‌ها)

از testwiki
پرش به ناوبری پرش به جستجو

در تحلیل الگوریتم‌ها، قضیه اصلی برای تحلیل مجانبی بسیاری از الگوریتم‌های تقسیم و حل استفاده می‌شود. در این نوع از الگوریتم‌ها معمولاً می‌توان یک رابطهٔ بازگشتی برای توصیف زمان اجرای آنها پیدا کرد. برای توصیف پیچیدگی چنین رابطه‌ای (به کمک نماد Θ) از این قضیه استفاده می‌شود.

البته نمی‌توان هر رابطهٔ بازگشتی را به کمک این قضیه حل کرد. روش اکرا-بازی تعمیمی از این قضیه است. این قضیه با کتاب معروف مقدمه‌ای بر الگوریتم‌ها به شهرت رسید.

شکل کلی

قضیه اصلی یک روش سرراست برای حل روابط بازگشتی به فرم زیر ارائه می‌کند:

T(n)=aT([nb])+f(n)

با فرض این که b>1 و a>0 و f(n)0 باشند.

این رابطهٔ بازگشتی زمان اجرای الگوریتمی را توصیف می‌کند T(n) که مسأله‌ای به اندازهٔ n را به a زیرمسأله (همگی به اندازهٔ تقریبی nb) تقسیم می‌کند. همچنین f(n) هزینهٔ تقسیم و ترکیب زیرمسائل است.

مقدار توان بحرانی ccrit را به صورت ccrit=logba تعریف می‌کنیم. در این صورت قضیه اصلی بیان می‌کند که:[۱]

حالت شرط f(n) شرح قضیه
۱ اگر c<ccrit:f𝒪(nc) آنگاه T(n)Θ(nccrit) خواهد بود.
۲ اگر fΘ(nccrit) باشد در آن صورت T(n)Θ(nccritlgn) می‌شود.
۳ اگر c>ccrit:fΩ(nc)و همچین شرط حالت طبیعی زیر برقرار باشدn0,k<1:nn0:af(nb)kf(n) T(n)Θ(f(n)) می‌شود.

توجه کنید این سه حالت بعضی حالت‌های ممکن برای f(n) را پوشش نمی‌دهند. یک شکاف بین حالت ۲ و ۳ (و همچنین بین حالات ۱ و ۲) وجود دارد. به عنوان مثال f=nccritlgn بین حالات ۲ و ۳ قرار می‌گیرد (یا f=nccrit/lgn بین ۱ و ۲). این شکاف زمانی پیش می‌آید که f(n) از nccrit بزرگتر (یا کوچکتر) باشد ولی مقدار بزرگتر (یا کوچکتر) بودنش به صورت چندجمله‌ای نباشد. در این صورت گاهی می‌توان از یک تعمیم کوچک برای حالت ۲ استفاده کرد:[۲]

حالت شرط f(n) شرط k شرح قضیه
۲ الف اگر fΘ(nccritlgkn) باشد به ازای هر k>1 آنگاه T(n)Θ(nccritlgk+1n) خواهد بود.
۲ ب و k=1 باشد در آن صورت T(n)Θ(nccritlglgn) می‌شود.
۲ ج به شرط k<1 T(n)Θ(nccrit) می‌شود.

مثال

برای پیدا کردن پیچیدگی جستجوی دودویی یا مرتب‌سازی ادغامی و بسیاری از الگوریتم‌های دیگر می‌توان از این قضیه استفاده کرد.

حالت ۱

الگو:وسط‌چین T(n)=8T(n2)+1000n2 الگو:پایان وسط‌چین

همان طور که در فرمول فوق دیده می‌شود، متغیرها دارای مقادیر زیر هستند:

الگو:وسط‌چین a=8، b=2، f(n)=1000n2، logba=log28=3 الگو:پایان وسط‌چین

حال باید برقراری معادلهٔ زیر را بررسی کنیم:

الگو:وسط‌چین f(n)=𝒪(nlogbaϵ) الگو:پایان وسط‌چین

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

درخت بازگشتی
درخت بازگشت

الگو:وسط‌چین

1000n2=𝒪(n3ϵ) الگو:پایان وسط‌چین

با انتخاب ϵ=1 داریم:

الگو:وسط‌چین 1000n2=𝒪(n31)=𝒪(n2) الگو:پایان وسط‌چین

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

الگو:وسط‌چین T(n)=Θ(nlogba). الگو:پایان وسط‌چین

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

الگو:وسط‌چین T(n)=Θ(n3). الگو:پایان وسط‌چین

از این رو رابطهٔ بازگشتی داده شده (T(n از(Θ(n³ است.

(راه حل دقیق رابطهٔ بازگشتی نیز این نتیجه را تأیید می‌کند، که در آن T(n)=1001n31000n2، بافرض T(1)=1 است.)

حالت ۲

الگو:وسط‌چین T(n)=2T(n2)+10n الگو:پایان وسط‌چین

همان طور که در فرمول فوق مشاهده می‌شود، متغیرها مقادیر زیر را اختیار می‌کنند:

الگو:وسط‌چین a=2، b=2، k=0، f(n)=10n، logba=log22=1 الگو:پایان وسط‌چین

حال می‌بایست برقراری رابطهٔ زیر را بررسی کنیم (در حالتی که k=۰ باشد):

درخت راه حل
درخت راه حل

الگو:وسط‌چین f(n)=Θ(nlogba) الگو:پایان وسط‌چین

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

الگو:وسط‌چین 10n=Θ(n1)=Θ(n) الگو:پایان وسط‌چین

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

الگو:وسط‌چین T(n)=Θ(nlogbalogn). الگو:پایان وسط‌چین

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

الگو:وسط‌چین T(n)=Θ(nlogn). الگو:پایان وسط‌چین

از این رو رابطهٔ بازگشتی داده شدهٔ (T(n از (Θ(n log n است.

(راه حل دقیق رابطهٔ بازگشتی نیز این نتیجه را تأیید می‌کند، که در آن T(n)=n+10nlog2n، بافرض T(1)=1 است.)

حالت ۳

الگو:وسط‌چین T(n)=2T(n2)+n2 الگو:پایان وسط‌چین

همان طور که در فرمول فوق دیده می‌شود، متغیرها مقادیر زیر را اختیار می‌کنند:

الگو:وسط‌چین a=2، b=2، f(n)=n2، logba=log22=1 الگو:پایان وسط‌چین

حال می‌بایست برقراری معادلهٔ زیر را مورد بررسی قرار دهیم:

الگو:وسط‌چین f(n)=Ω(nlogba+ϵ) الگو:پایان وسط‌چین

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

الگو:وسط‌چین n2=Ω(n1+1)=Ω(n2) الگو:پایان وسط‌چین

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

الگو:وسط‌چین af(nb)cf(n) الگو:پایان وسط‌چین

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

الگو:وسط‌چین cn212n2cn2 2(n2)2 الگو:پایان وسط‌چین

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

الگو:وسط‌چین n1 12n212n2 الگو:پایان وسط‌چین

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

الگو:وسط‌چین T(n)=Θ(f(n)). الگو:پایان وسط‌چین

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

الگو:وسط‌چین T(n)=Θ(n2). الگو:پایان وسط‌چین

از این رو رابطهٔ بازگشتی داده شده (T(n از (Θ(n² است.

(راه حل دقیق رابطهٔ بازگشتی نیز این نتیجه را تأیید می‌کند، که در آن T(n)=2n2n، بافرض T(1)=1 است.)


در روش درخت بازگشتی ، کل کارهای انجام شده را محاسبه می کنیم. اگر کارهایی که در برگها انجام می شود چند جمله ای بیشتری است ، پس برگها قسمت اصلی هستند و نتیجه ما به کارهایی که در برگها انجام می شود تبدیل می شود (حالت 1). اگر کارهایی که در برگ و ریشه انجام می شود به صورت یکسان باشد ، نتیجه کار ما با کارهایی که در هر سطح انجام می شود ضرب می شود (حالت 2). اگر کارهایی که در ریشه انجام می شوند بیشتر از لحاظ غیرمتعارف باشند ، نتیجه ما به کارهایی در ریشه انجام می شود (حالت 3).

حالت‌های ناپذیرفتنی

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

الگو:وسط‌چین T(n)=2nT(n2)+nn الگو:پایان وسط‌چین a مقدار ثابت نیست.

الگو:وسط‌چین T(n)=2T(n2)+nlogn الگو:پایان وسط‌چین اختلاف بین (f(n و nlogba غیر چندجمله‌ای است.

الگو:وسط‌چین T(n)=0.5T(n2)+n الگو:پایان وسط‌چین a<۱ است درحالی که نمی‌توان کم تر از یک زیر مسئله داشت.

الگو:وسط‌چین T(n)=64T(n8)n2logn: الگو:پایان وسط‌چین (f(n مثبت نیست.


صحت قضیه اصلی

نشان دادن درست بودن این قضیه در حالت کلی کار ساده ای نیست اما در ادامه صحت این قضیه را برای یک حالت خاص بررسی می کنیم.

فرض می کنیم (f(n تابعی از مرتبه چندجمله ای باشد یعنی (f(n) = Θ(nd آنگاه :

T(n)=aT(nb)+nd

پس داریم :

logb a > d −→ T(n) = Θ(nlogbb a)

logb a = d −→ T(n) = Θ(nlog a)

logb a < d −→ T(n) = Θ(nd)


میخواهیم مجموع هزینه ها را به دست بیاوریم پس درخت بازگشت آن را رسم میکنیم. برای هر سطح در درخت هزینه های زیر را داریم :

هزینه ی رأسها در سطح ۱:cnd

هزینه ی رأسها در سطح ۲: ac(nb)d

...

هزینه ی رأسها در سطحi :ai1c(nbi1)d

برای محاسبه هزینه کل ، هزینه های هر سطح را با هم جمع میزنیم.( تحلیل سرشکن )

مقدار رأس ریشه در درخت برابرnd  است. به جز راسهای برگ ، هر رأس در این درختa  فرزند دارد که مقدار هرکدامb )-d ) برابر مقدار پدرش است؛ یعنی به عنوان مثال فرزندان ریشه مقداری برابر(nb)d  دارند. و هزینهی هر برگc است.  

با محاسبه جمع مقادیر سطوح مختلف درخت به مجموع کل میرسیم:

T(n)i=0log(nb)1Cai(nbi)d+θ(nlogba)

که این مقدار هزینهی متناظر با ریشه (T(n است را تعیین میکند.

قضیه اصلی برای تفریق و حل بازگشتی

قضیه اصلی واکاوی الگوریتم‌ها برای تعیین کارکردهای دارای محدودیت بالایی Big - O استفاده می شود ، که می تواند در مسایل فرعی شکسته شود.قضیه اصلی برای تکرار تفریق و تقسیم:بگذارید T (n) تابعی باشد که مطابق شکل زیر در n مثبت نشان داده شده است:[۳]


قضیه اصلی برای تفریق و حل بازگشتی:

قضیه اصلی برای منها کردن
قضیه اصلی برای منها کردن

فرض کنید T (n) تابعی باشد که مطابق شکل در n مثبت نشان داده شده است:

1. If a<1 then T(n) = O(nk)

2. If a=1 then T(n) = O(nk+1)

3. if a>1 then T(n) = O(nkan/b)

جستارهای وابسته

منابع

الگو:پانویس الگو:چپ‌چین.

  • Michael T. Goodrich and Roberto Tamassia. Algorithm Design: Foundation, Analysis, and Internet Examples. Wiley, 2002. الگو:شابک. The master theorem (including the version of Case 2 included here, which is stronger than the one from CLRS) is on pp. 268–270.
  • الگو:یادکرد-ویکی

الگو:پایان چپ‌چین