מבנה נתונים תמציתי

מתוך ויקיפדיה, האנציקלופדיה החופשית
קפיצה לניווט קפיצה לחיפוש

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

עבור מידע מסוים, אם על פי תורת האינפורמציה דרושים ביטים לייצוג של המידע, אזי ייצוג של המידע יקרא:

  • מרומז אם הוא צורך  ביטים של זיכרון.
  • תמציתי אם הוא צורך ביטים של זיכרון,
  • קומפקטי אם הוא צורך ביטים של זיכרון.

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

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

מילונים תמציתיים[עריכת קוד מקור | עריכה]

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

  • דרגה (rank) - שאילתה המקבלת אינדקס i של איבר ואיבר q () ומחזירה את מספר האיברים ב-B עד האינדקס i שהערך שלהם הוא q. פורמלית: .
  • בחר (select) - שאילתה המקבלת אינדקס i ואיבר q () ומחזירה את המיקום של האיבר ה-i שהערך שלו הוא q. פורמלית: .

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

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

בפועל, ניתן להחליף את טבלת החיפוש  בפעולות על ביטים ובטבלאות קטנות יותר כדי למצוא את מספר הביטים הדולקים בבלוקים הקטנים. זה לעיתים קרובות מועיל, שכן מבני נתונים תמציתיים משמשים למערכות נתונים גדולות, שבהן החטאות מטמון נעשות הרבה יותר תכופות, והסיכויים שטבלת החיפוש תפונה מהמטמון גדלים.[5] ניתן לתמוך בקלות בשאילתות בחירה על ידי ביצוע חיפוש בינארי על אותו מבנה עזר המשמש לפעולות דרגה; עם זאת, דבר זה דורש זמן במקרה הגרוע ביותר. ניתן להשתמש במבנה מסובך יותר המשתמש ב- ביטים של זיכרון נוסף, כדי לתמוך בפעולות בחירה בזמן קבוע.[6] למעשה, ברבים מהפתרונות האלה מוסתרים קבועים בסימון  אשר שולטים בבעיה לפני שניכר יתרון אסימפטוטי כל שהוא; יישומים באמצעות פעולות נרחבות על מילים ובלוקים של מילים-מיושרות לעיתים קרובות מראים ביצועים טובים יותר בפועל.[7]

מילונים דחוסי-אנטרופיה[עריכת קוד מקור | עריכה]

גישת ה- זיכרון ניתנת לשיפור בזכות ההבחנה כי ישנם  תתי קבוצות של  באורך (או מחרוזות בינאריות באורך   עם בדיוק 1ים), ולכן הוא החסם התחתון של תורת האינפורמציה על מספר הביטים הדרושים לאחסון . ישנו מילון (סטטי) תמציתי המשיג את החסם הזה, דהיינו משתמש ב- זיכרון.[8] ניתן להרחיב את המבנה הזה כדי לתמוך בשאילתות דרגה ובחירה, תוך שימוש ב-  זיכרון.[2] ניתן לצמצם את החסם הזה לתחלופת זיכרון/זמן על ידי הקטנת מקום האחסון של המילון ל- וזמן שאילתה  .[9]

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

כאשר צריך לקודד רצף של פריטים בעלי אורך משתנה (כגון מחרוזות), ישנן מספר אפשרויות: גישה ישירה היא לשמור את האורך ואת הפריט באותה רשומה- והללו יכולות להיות ממוקמות אחת אחרי השנייה. זה מאפשר מעבר יעיל לעוקב, אבל לא מוצא את הפריט ה. אופציה נוספת היא למקם את הפריטים לפי הסדר עם תו מפריד (למשל, מחרוזת עם סיומת אפס). אפשרות זו משתמשת במפריד במקום באורך, והיא איטית יותר באופן משמעותי, מפני שיש לסרוק את כל הרצף כדי למצוא תווים מפרידים. שתי האפשרויות יעילות מבחינת זיכרון. גישה אחרת היא הפרדה מאוגדת: ניתן למקם את הפריטים זה אחר זה, ללא מפרידים. ניתן לשמור את גבולות הפריט יכולים כרצף של אורכים, או באופן יעיל יותר, כהיסטים בתוך רצף זה. לחלופין, מקודדים בנוסף מחרוזת בינארית נפרדת המורכבת מ1ים במקומות בהם פריט מתחיל, ו0ים בכל מקום אחר. בהינתן המחרוזת זאת, פונקציית ה יכולה לקבוע במהירות היכן כל פריט מתחיל, בהינתן האינדקס שלו.[10] מבנה זה קומפקטי אך לא תמציתי, היות שהוא צורך 2Z זיכרון, דהיינו (O(Z.

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

לקריאה נוספת[עריכת קוד מקור | עריכה]

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

  1. ^ Jacobson, G. J (1988). Succinct static data structures (Ph.D.). Pittsburgh, PA: Carnegie Mellon University.
  2. ^ 2.0 2.1 Raman, R.; V. Raman; S. S Rao (2002). "Succinct indexable dictionaries with applications to encoding k-ary trees and multisets". Proceedings of the thirteenth annual ACM-SIAM symposium on Discrete algorithms. עמ' 233–242. ISBN 0-89871-513-X. 
  3. ^ Sadakane, K.; R. Grossi (2006). "Squeezing succinct data structures into entropy bounds". Proceedings of the seventeenth annual ACM-SIAM symposium on Discrete algorithm. עמ' 1230–1239. ISBN 0-89871-605-5. 
  4. ^ Jacobson, G. (1989). "Space-efficient static trees and graphs". 
  5. ^ González, R.; S. Grabowski; V. Mäkinen; G. Navarro (2005). "Practical implementation of rank and select queries". Poster Proceedings Volume of 4th Workshop on Efficient and Experimental Algorithms (WEA). עמ' 27–38. 
  6. ^ Clark, D. (1998). "Compact pat trees". 
  7. ^ Vigna, S. (2008). "Broadword implementation of rank/select queries". Experimental Algorithms. Lecture Notes in Computer Science 5038: 154–168. ISBN 978-3-540-68548-7. doi:10.1007/978-3-540-68552-4_12. 
  8. ^ Brodnik, A.; J. I Munro (1999). "Membership in constant time and almost-minimum space". SIAM J. Comput. 28 (5): 1627–1640. doi:10.1137/S0097539795294165. 
  9. ^ Pătraşcu, M. (2008). "Succincter". Foundations of Computer Science, 2008. FOCS'08. IEEE 49th Annual IEEE Symposium on. עמ' 305–313. 
  10. ^ Belazzougui, Djamal. "Hash, displace, and compress".