הבדלים בין גרסאות בדף "סיבוכיות"

נוספו 44 בתים ,  לפני 7 שנים
מ (שוחזר מעריכות של 31.44.143.6 (שיחה) לעריכה האחרונה של Matanya)
==מאפייני הסיבוכיות==
 
'''בעיה''', בהקשר זה, היא [[קבוצה (מתמטיקה)|קבוצה]] של שאלות בעלות קשר הדוק. דוגמה: הבעיהבעיית ה[[פירוק מספר שלם לגורמים|פירוק לגורמים]] היא: כאשר נתון מספר שלם כלשהו, הצג את כל ה[[גורם ראשוני|גורמים הראשוניים]] שלו. שאלה ספציפית קרויה '''מופע''' של הבעיה. דוגמה: השאלה "הצג את הגורמים של המספר 15" היא מופע של בעיית הפירוק לגורמים.
 
'''סיבוכיות הזמן''' של בעיה נתונה היא מספר הצעדים הנחוצים לפתרון מופע שלה כפונקציה של גודל הקלט של מופע זה, תוך שימוש באלגוריתם היעיל ביותר למטרה זו. אם לפתרונו של מופע שאורך הקלט שלו הוא n [[סיבית|סיביות]] נחוצים n<sup>2</sup> צעדים, סיבוכיות הזמן שלו היא n<sup>2</sup>. מספר הצעדים המדויק תלוי במחשב המסוים שישמש לפתרון הבעיה. כדי להימנע מהתייחסות למחשב מסוים נהוג להשתמש במודל מתמטי עבור מחשב: [[מכונת טיורינג]]. בנוסף, כדי להימנע מחישובים טכניים מדי ומכיוון שעיקר העניין הוא הקצב שבו כמות המשאבים הנדרשים גדלה ככל שהקלט לבעיה גדל, נהוג לסמן את סיבוכיות הזמן באמצעות [[סימון אסימפטוטי]] שמייצג '''סדר גודל''' של זמן הריצה, ולמדוד את זמן הריצה על פי מספר הביצועים של פעולות בסיסיות (כמו ביצוע פעולה אריתמטית, קריאת ערך של תא בזיכרון וכדומה). בצורה זו סיבוכיות הזמן מייצגת את הזמן הנחוץ לפתרונה בכל מחשב מסוים (עד כדי הכפלה או הוספה של קבוע שתלוי ברמת הביצועים של המחשב המסוים הזה), כך שהסיבוכיות המוצגת אינה תלויה במחשב שישמש לפתרון הבעיה ואינה מציגה את הזמן הדרוש לפתרון הבעיה ב[[שנייה|שניות]], אלא מייצגת את סדר הגודל של הזמן הנחוץ לפתרון הבעיה כפונקציה של אורך הקלט.