האלגוריתם של קרוסקל

האלגוריתם של קרוסקל הוא אלגוריתם חמדן לפתרון בעיית מציאת עץ פורש מינימלי בגרף ממושקל קשיר לא מכוון, שתואר לראשונה במאמר של ג'וזף קרוסקל בשנת 1956. המטרה היא למצוא תת קבוצה של הקשתות שתיצור עץ המכיל את כל קודקודי הגרף (עץ כזה נקרא עץ פורש) שמשקלו מינימלי. כלומר סכום משקלי הקשתות המרכיבות אותו קטן או שווה לסכום משקלי הקשתות בכל עץ פורש אחר. ייתכן שלגרף נתון יהיו כמה עצים פורשים מינימליים.

האלגוריתם של קרוסקל
סיבוכיות זמן O(E \log V) עריכת הנתון בוויקינתונים
ממציא ג'וזף קרוסקל עריכת הנתון בוויקינתונים
נקרא על שם ג'וזף קרוסקל עריכת הנתון בוויקינתונים
לעריכה בוויקינתונים שמשמש מקור לחלק מהמידע בתבנית

האלגוריתם ממיין את הקשתות לפי משקליהן תחילה. אחר כך עובר על הקשתות מהקשת המינימלית עד לקשת הגדולה ביותר במשקלה, ומוסיף כל קשת לעץ הפורש כל עוד הוספתה לא יוצרת מעגל בגרף המתקבל. תת הגרף שמתקבל לבסוף הוא עץ פורש מינימלי.

האלגוריתם הוא חמדן, כיוון שבכל צעד נבחרת הפעולה הנראית אופטימלית באותו שלב - נוטלים את הקשת שמשקלה הקטן ביותר.

סיבוכיות האלגוריתם מושפעת בעיקר מהצורך למיין את הקשתות בתחילת הפעלתו. בגרף עם קבוצת קודקודים וקבוצת קשתות הסיבוכיות תהיה חסומה על ידי במקרה הכללי, הסיבוכיות המינימלית למיון מבוסס השוואות של איברים. עם זאת, במקרה והקשתות כבר ממויינות או שניתן למיין אותן בזמן ליניארי (לדוגמה מיון בסיס כשהמשקלים קטנים), על ידי שימוש במבנה נתונים של איחוד קבוצות זרות זמן הריצה יהיה כש- היא הפונקציה ההופכית לפונקציית אקרמן (פונקציה הגדלה לאט מאוד).

פסאודו קוד

עריכה

הקוד הבא מסתמך על מבנה נתונים לאיחוד קבוצות זרות:

KRUSKAL(G):
1 A = ∅
2 foreach v ∈ G.V:
3   MAKE-SET(v)
4 foreach (u, v) ordered by weight(u, v), increasing:
5    if FIND-SET(u) ≠ FIND-SET(v):
6       A = A ∪ {(u, v)}
7       UNION(FIND-SET(u), FIND-SET(v))
8 return A

דוגמה

עריכה
תמונה תיאור
  זה הגרף המקורי שלנו. המספרים ליד הקשתות מציינים את משקלן, אף קשת לא מודגשת.
  הקשתות AD ו-CE שמשקלן 5 הן הקלות ביותר. AD נבחרה באופן שרירותי והודגשה.
  כעת CE שמשקלה 5 היא הקשת הקלה ביותר שאינה סוגרת מעגל, ולכן מודגשת.
  הקשת הקלה ביותר הבאה שאינה סוגרת מעגל היא DF שמשקלה 6.
  כעת הקשתות הקלות ביותר הן AB ו-BE שאורכן 7. AB נבחרת באופן שרירותי ומודגשת. הקשת BD נצבעת באדום כיוון שכבר קיים מסלול בין B ל-D (בירוק), ולכן היא תיצור מעגל (ABD) אם תיבחר.
  התהליך ממשיך ו-BE נצבעת בירוק. בשלב זה מספר קשתות נצבעות באדום: BC (כי היא תיצור את המעגל BCE), הקשת DE (כי היא תיצור את המעגל DEBA), ו-EF (שתיצור את המעגל FEBAD).
  לבסוף, התהליך מסתיים עם בחירת הקשת EG שמשקלה 9, ומציאת עץ פורש מינימלי (בירוק).

ראו גם

עריכה

קישורים חיצוניים

עריכה