BFS לעומת DFS

מְחַבֵּר: Laura McKinney
תאריך הבריאה: 4 אַפּרִיל 2021
תאריך עדכון: 17 מאי 2024
Anonim
אלגוריתם BFS
וִידֵאוֹ: אלגוריתם BFS

תוֹכֶן

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


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

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


תוכן: הבדל בין BFS ל- DFS

  • טבלת השוואה
  • BFS
  • DFS
  • הבדלים עיקריים
  • סיכום
  • סרטון הסבר

טבלת השוואה

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

BFS

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


DFS

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

הבדלים עיקריים

  1. חיפוש רוחב ראשון הוא שיטת חציית גרפים המשתמשת בתור לאחסון קודקודים שביקרו ואילו חיפוש עומק ראשון הוא שיטת מעבר גרפים המשתמשת בערימה לאחסון קודקודים שביקרו בהם.
  2. חיפוש הראשון ברוחב הוא אלגוריתם מבוסס קודקוד ואילו חיפוש הראשון בעומק הוא אלגוריתם מבוסס קצה
  3. חיפוש ראשון-רוחב הוא לא יעיל בזיכרון ואילו חיפוש הראשון-עומק יעיל בזיכרון.
  4. בוחן את הגרף הדו-חלקי, המרכיב המחובר והנתיב הקצר ביותר המופיע בתרשים ואילו בוחן גרף מחובר דו-קצה, גרף מחובר חזק, גרף acyclic וסדר topological.

סיכום

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

סרטון הסבר