משפט זרימה מקסימלית - חתך מינימלי

בתורת הגרפים, משפט זרימה מקסימלית - חתך מינימלי (Max-flow min-cut) עוסק בזרימה המקסימלית שניתן להעביר ברשת זרימה. המשפט קובע כי כמות הזרימה המקסימלית שניתן להעביר ברשת זרימה שווה לקיבולת המקסימלית של החתך עם הקיבולת המינימלית ברשת.

המשפט הוא מקרה פרטי של הדואליות של תכנון ליניארי ומכליל את משפט מנגר הקובע כי גרף הוא k-קשיר אם ורק אם בין כל שני קודקודים בגרף קיימים k מסלולים זרים בקודקודים והוא k-קשיר-קשתות אם ורק אם בין כל שני קודקודים בגרף קיימים k מסלולים זרים בקשתות.

תיאור פורמלי עריכה

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

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

קיבול של חתך מוגדר באמצעות סכום הקיבולות של הקשתות המצביעות מצומת בקבוצה   לצומת בקבוצה   (יש לשים לב שההגדרה אי-סימטרית):

 

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

 

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

פונקציית זרימה   מתאימה לכל זוג צמתים   את כמות הזרימה מ-  אל   (לכיוון יש חשיבות), כך שמתקיימים התנאים הבאים:

  1. אנטי-סימטריה:  
  2. שמירה על אילוץ הקיבול:  
  3. שימור הזרימה: לכל   מתקיים:  

הערך של זרימה היא סך הזרימה שיוצאת מן המקור, כלומר  .

עבור רשת זרימה   עם פונקציית קיבול   וזרימה חוקית   הגרף השיורי (residual graph) הוא רשת זרימה עם אותה קבוצת צמתים וקשתות כך שהקיבול של קשת (u,v) הוא  .

משפט זרימה מקסימלית - חתך מינימלי אומר כי שלושת התנאים הבאים שקולים, עבור זרימה  :

  1.   היא זרימה מקסימלית ברשת הזרימה.
  2. הגרף השיורי של רשת הזרימה עבור הזרימה   לא מכיל מסלולי שיפור.
  3. כמות הזרימה שווה לקיבול של חתך כלשהו:  .

גרסה נוספת עריכה

קיימת גם גרסה של המשפט בו ערכי הזרימה הם מספרים טבעיים (integral version), כלומר המשפט נכון גם כאשר פונקציית הזרימה היא  .שאר ההגדרות והדרישות על פונקציית הזרימה נותרות בעינן. ראו גם[1]

הוכחה עריכה

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

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

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

הגרירה של 3 את 1 היא מיידית שכן קל להראות שהערך של כל זרימה קטן או שווה לקיבולו של כל חתך בגרף.

ראו גם עריכה

קישורים חיצוניים עריכה

הערות שוליים עריכה

  1. ^ Distel, C6, Graph Theory, מהדורה חמישית. (באנגלית)