الگوریتم حذف معکوس
در نظریهٔ گراف الگوریتم حذف معکوس(به انگلیسی: Reverse-delete algorithm) الگوریتمی است که در یک گراف همبند، با یال وزن دار درخت پوشای کمینه را بدست میآورد. اگر گراف ناهمبند باشد این الگوریتم درخت پوشای کمینه را برای هر مولفهٔ همبندی مییابد که در این صورت مجموعهٔ این درختهای پوشای کمینه را یک جنگل پوشای کمینه گویند.
این الگوریتم الگوریتمی حریصانه است که در هر لحظه بهترین انتخاب را انجام میدهد و برعکس الگوریتم کروسکال که الگوریتم دیگری برای پیدا کردن درخت پوشای کمینهاست، عمل میکند. الگوریتم کراسکال با یک گراف خالی شروع میکند و یالها را به آن اضافه میکند در حالیکه الگوریتم حذف معکوس با گراف اصلی شروع میکند و یالها را از آن حذف میکند. الگوریتم به صورت زیر عمل میکند:
- با گراف G که لیستی از یالهای E دارد شروع کن.
- E را به ترتیب نزولی وزن یالها مرتب کن.
- برای هر یال چک کن که آیا حذف این یال گراف را ناهمبند میکند یا نه.
- اگر حذف کردن منجر به ناهمبندی گراف نمیشود یال را حذف کن
اثبات درستی
الگوریتم حذف معکوس این تضمین را میدهد که گراف همبند باقی بماند، چون تنها در صورتی یالی را حذف میکند که باعث ناهمبند شدن گراف نشود. هر یالی که حذف میشود قبل از حذف در دوری شرکت داشتهاست. از آنجایی که الگوریتم از یال با بیشترین وزن شروع به حذف کردن میکند، آن یال بزرگترین یال در دور مربوط به خود است. پس بنابر تعریف درخت پوشای کمینه، یال حذف شده جزء درخت پوشای کمینه نخواهد بود.
شبه برنامه
1 function ReverseDelete(edges[] E) 2 sort E in decreasing order 3 Define an index i ← 0 4 while i <size(E) 5 Define edge temp ← E[i] 6 delete E[i] 7 if temp.v1 is not connected to temp.v2 8 E[i] ← temp 9 i ← i + 1 10 return edges[] E
در بالا گراف، مجوعه یالهای وزن دار E است که هر یال آن وزنی دارد و دو راس v1 و v2 را به هم متصل میکند.
مثال
در مثال زیر یالهای سبز توسط الگوریتم انتخاب شدهاند و یالهای قرمز حذف شدهاند.
زمان اجرا
میتوان نشان داد که الگوریتم در زمان (O(E log E (log log E)3 انجام میشود که E تعداد یالها و V تعداد گرههای گراف است. این حد به صورت زیر محاسبه شدهاست:
مرتب سازی یالها با استفاده از الگوریتم مرتب سازی مقایسهای در زمان (O(E log E انجام میگیرد حلقه E بار تکرار میشود.
حذف کردن یال در(O(1 زمان انجام میگیرد.
همبندی در زمان (O(log V (log log V) انجام میگیرد.
زمان اجرا را میتوان (O(E log V (log log V) در نظر گرفت زیرا E حداکثر V است. یادآوری log V = 2 * log V که ثابت ۲ در نوشتار big-O نادیده گرفته میشود.
منابع
- ↑ مشارکتکنندگان ویکیپدیا. «Reverse-delete algorithm». در دانشنامهٔ ویکیپدیای انگلیسی، بازبینیشده در ۱۱ نوامبر ۲۰۱۰.