עץ פורש מינימלי

עץ פורשׂ מינימליאנגלית: Minimum spanning tree) של גרף ממושקל לא מכוון הוא עץ פורש (כלומר, תת-גרף קשיר ונטול מעגלים המכיל את כל הצמתים בגרף), שהוא מינימלי בסכום משקלי הקשתות שלו מבין כל העצים הפורשים.[1][2]

בכתיב פורמלי: אם משקל הקשת הוא ועבור עץ יהי משקלו , העץ הפורש המינימלי הוא זה בעל הקטן ביותר.

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

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

ריבוי אפשרי

[עריכת קוד מקור | עריכה]
דוגמה לגרף ממושקל (למעלה) עם יותר מעץ פורש מינימלי אחד

אם בגרף n קודקודים, אזי לכל עץ פורש n − 1 קשתות.

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

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

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

  1. בדרך השלילה: נניח שקיימים שני עצים פורשים מינימליים A ו-B.
  2. מכיוון ש-A ו-B שונים, למרות שהם כוללים אותם צמתים, קיימת קשת אחת או יותר ששייכת לעץ פורש מינימלי אחד אך לא לאחר. מבין הקשתות הללו, תהי הקשת בעלת המשקל הנמוך ביותר; בחירה זו היא ייחודית מכיוון שכל משקלי הקשתות שונים. ללא הגבלת הכלליות, נניח ש- נמצאת ב-A.
  3. מכיוון ש-B הוא עץ פורש מינימלי חייב להכיל מעגל C, הכולל את .
  4. A הוא עץ ולכן אינו מכיל מעגלים, לכן C חייב לכלול קשת שאינה ב A.
  5. מאחר שהקשת נבחרה כקשת בעלת המשקל הנמוך ביותר מבין הקשתות השייכות בדיוק לאחד מ-A ו-B, המשקל של חייב להיות גדול מהמשקל של .
  6. כיוון שהקשתות ו- הן חלק מהמעגל C, החלפת ב- ב-B יוצרת עץ פורש עם משקל קטן יותר, בניגוד להנחה ש-B הוא עץ פורש מינימלי.

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

גרף הכולל מעגלים

[עריכת קוד מקור | עריכה]

אם המשקל של קשת במעגל כלשהו C בגרף גדול מהמשקלות של שאר כל שאר הקשתות של C, אז קשת זו אינה שייכת לאף עץ פורשת מינימלי.

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

התפתחות האלגוריתם

[עריכת קוד מקור | עריכה]

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

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

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

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

[עריכת קוד מקור | עריכה]

הערות שוליים

[עריכת קוד מקור | עריכה]
  1. ^ minimum_spanning_tree — SciPy v1.14.1 Manual, docs.scipy.org
  2. ^ Eric W. Weisstein, Minimum Spanning Tree, mathworld.wolfram.com (באנגלית)
  3. ^ Do the minimum spanning trees of a weighted graph have the same number of edges with a given weight?, Computer Science Stack Exchange