{
"cells": [
{
"cell_type": "markdown",
"metadata": {},
"source": [
""
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"#
תרגילים
" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "##בחירות במדינת הגמדים
" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "\n",
" במדינת הגמדים רעש מהומה, ולכן החליטו ללכת לבחירות.
\n",
" ועדת הבחירות המרכזית, בראשות דרדסבא, ערכה בחירות חשאיות והוגנות והציגה לפניכם את התוצאות בקובץ elections.txt המצורף (בתיקיית resources), על כל 353,400 בוחריה.
\n",
" הקובץ הינו רשימה של שמות המפלגות שבהן בחרו תושבי מדינת הגמדים, כאשר כל שורה מייצגת בחירה של תושב מדינת הגמדים.
\n",
" כדי לשמור על טוהר הבחירות לא נאמר לכם במפורש מהו מספר המפלגות שהגישו את רשימותיהן לוועדת הבחירות.
\n",
" עליכם הוטלה המשימה לעבור על קובץ תוצאות הבחירות ולדווח כמה קולות קיבלה כל מפלגה.
\n",
" כתבו פונקציה שלא מקבלת פרמטרים ומחזירה את תוצאות הבחירות במילון ובו שם המפלגה ומספר הקולות שקיבלה.\n",
"
\n",
" אחוז החסימה במדינת הגמדים הוא אכזרי למדי ועומד על 10%.
\n",
" כיון שהצביעו 353,400 גמדים – אחוז החסימה עומד על\n",
" $353,400*0.1=35,340$ קולות.
\n",
" כתבו פונקציה המקבלת את מילון תוצאות הבחירות ומדפיסה אילו מפלגות עברו את אחוז החסימה ואילו לא.\n",
"
\n", "כעת כתבו פונקציה המקבלת את מילון תוצאות הבחירות ומחזירה את מספר הקולות שקיבלו רק מפלגות שעברו את אחוז החסימה.
" ] }, { "cell_type": "code", "execution_count": null, "metadata": {}, "outputs": [], "source": [] }, { "cell_type": "markdown", "metadata": {}, "source": [ "\n", " אחרי שסיימתם בדקו שקיבלתם את הערך הבא: 249,333\n", "
" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "\n",
" לאחר קבלת תוצאות האמת המפלגות פועלות להקים קואליציה. קואליציה מורכבת מ־61 מנדטים לפחות.
\n",
" מנדט שווה: $\\dfrac{votes}{120}=2.077.775\\cong2,078$ קולות.
\n",
" שימו לב, הקולות בתרגיל זה הם התוצאה של הסעיף הקודם. כלומר הקולות בניכוי הקולות עבור מפלגות שלא עברו את אחוז החסימה.
\n",
" כעת כתבו פונקציה המקבלת את מילון התוצאות ומחזירה מילון שבו שם המפלגה ממופה עם מספר המנדטים שקיבלה המפלגה.
\n",
" הפעילו את פונקנציית round
על תוצאת החלוקה (השתמשו ב־2,078) כדי לקבל את מספר המנדטים השלם.\n",
"
\n", "הדפיסו את המילון שקיבלתם. ודאו שסך המנדטים מסתכם ל־120.
" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "\n",
"כדי להרכיב קואליציה דרושים 61 מנדטים.
\n",
"המפלגות MidgeLandIsUs ו־NilsIsALeader לא מוכנות לשבת יחד בקואליציה.
\n",
"כתבו פונקציה המקבלת את המילון המכיל את תוצאות המנדטים ומדפיסה קואליציה אפשרית עבור NilsIsALeader וקואליציה אפשרית עבור MidgeLandIsUs.\n",
"
Leveraging Simple Dictionaries
" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "###הקדמה
" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "\n",
" אוטומט סופי דטרמיניסטי הוא מודל מתמטי שמגדיר אוסף של מצבים, וכללי מעבר ביניהם.
\n",
" נפתח בדוגמה:
\n",
" \n",
"
\n",
" לפניכם מכונת מצבים שמקבלת מספר, ובודקת האם הוא זוגי.
\n",
" כל מצב מיוצג בתמונה על ידי עיגול, וכללי המעבר ביניהם מיוצגים באמצעות חצים.\n",
"
\n",
" המכונה מתחילה מ\"מצב התחלתי\" נתון כלשהו, במקרה שלנו \"מספר אי זוגי\".
\n",
" כל פעם שמתקבל קלט חדש, המכונה מחליטה לאיזה מצב לעבור לפי כללי המעבר הרשומים על החצים.
\n",
" לדוגמה, עבור הקלט 2 ואז 7 ואז 4 (274) מכונת המצבים המופיעה מעלה תבצע את הפעולות הבאות:\n",
"
\n",
" לכל מצב באוטומט סופי דטרמיניסטי יש \"סוג מצב\": מקבל או לא מקבל.
\n",
" מצב מקבל מסומן בעיגול כפול, כמו המצב \"מספר זוגי\" באוטומט דלעיל.
\n",
" אם בסוף הריצה הגענו למצב מקבל, סימן שהקלט תקין, ואם לא – סימן שהקלט אינו תקין.
\n",
" באוטומט הדוגמה שלנו כל קלט מספרי זוגי הוא תקין, וכל מספרי אי־זוגי נחשב ללא תקין.\n",
"
\n",
" כל אפשרות הכלולה במצבי המעבר נקראת אות. אוסף כל האותיות הכלולות באוטומט מסוים נקרא א\"ב הקלט.
\n",
" שימו לב שבאוטומט יכולה להיות כמות גדולה של מצבים וכללי־מעבר, ובכל אוטומט יכול להיות יותר ממצב מקבל אחד.
\n",
" כמו כן, \"אות\" בא\"ב יכולה לכלול יותר מתו אחד.\n",
"
תרגיל
" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "\n",
" כתבו תוכנה שקוראת קובץ ויוצרת ממנו אוטומט סופי דטרמיניסטי.
\n",
" בקובץ ישנו כל המידע הדרוש לבניית האוטומט, ורשימת קלטים. דוגמה לקובץ שכזה מופיעה מטה.
\n",
" הדפיסו עבור כל קלט האם לאחר הרצתו האוטומט הגיע למצב מקבל או למצב לא מקבל.\n",
"
\n", " הקובץ שהתוכנה שלכם אמורה לקרוא ונועד לתאר את האוטומט המופיע למעלה נראה כך:\n", "
" ] }, { "cell_type": "raw", "metadata": {}, "source": [ "Definitions:\n", "States: q0, q1\n", "Start: q0\n", "Accepting: q1\n", "\n", "Transitions:\n", "q0: 2, 4, 6, 8, 0 -> q1\n", "q0: 1, 3, 5, 7, 9 -> q0\n", "q1: 2, 4, 6, 8, 0 -> q1\n", "q1: 1, 3, 5, 7, 9 -> q0\n", "\n", "Inputs:\n", "1, 3, 1\n", "2, 7, 4\n", "2, 2, 2, 2" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "\n", " על התוכנה שבניתם להדפיס במקרה הזה:\n", "
" ] }, { "cell_type": "raw", "metadata": {}, "source": [ "False\n", "True\n", "True" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "###הסבר עבור הדוגמה
" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "\n",
" הפסקה הראשונה תמיד תראה כך:
\n",
" הקובץ תמיד יפתח במילה Definitions:
.
\n",
" שורה אחריה תמיד תופיע המילה States:
, ואחריה כל המצבים הקיימים במכונת המצבים, מופרדים בפסיק.
\n",
" שורה אחריה תמיד תופיע המילה Start:
, ואחריה המצב ההתחלתי של המכונה.
\n",
" שורה אחריה תמיד תופיע המילה Accepting:
, ואחריה כל המצבים שמוגדרים כמצבים מקבלים במכונת המצבים, מופרדים בפסיק.
\n",
"
\n",
" הפסקה השנייה תמיד תראה כך:
\n",
" הפסקה תמיד תפתח במילה Transitions:
, ואחריה רשימה של כללי מעבר.
\n",
" כל כלל מעבר מורכב מהמצב ממנו יוצאים, המצב אליו מגיעים ומה הקלט ש\"מפעיל\" את המעבר.
\n",
" השורה תכתב באופן הבא, כאשר X הוא המצב ממנו יוצאים, Z הוא המצב אליו מגיעים ו־Y היא רשימת הקלטים שמפעילה את מצב המעבר:
\n",
" X: Y -> Z
\n",
"
\n",
" הפסקה השלישית תמיד תראה כך:
\n",
" הפסקה תמיד תפתח במילה Inputs:
, ואחריה רשימה של קלטים תקינים.
\n",
" כל שורת קלט תופיע בשורה נפרדת בקובץ, ותכלול את רצף הקלטים שיועברו לאוטומט אחד אחרי השני, כאשר הם מופרדים בפסיק.\n",
"
\n",
" עבור הקלט הראשון, האוטומט יתחיל מהמצב ההתחלתי q0. האות 1 תשאיר אותו שם, כך גם 3, כך גם 1. מצב לא מקבל.
\n",
" עבור הקלט השני, האוטומט יתחיל מהמצב ההתחלתי q0. האות 2 תעביר אותו ל־q1, האות 7 תעביר אותו ל־q0, האות 4 תעביר אותו חזרה ל־q1. מצב מקבל.
\n",
" עבור הקלט השלישי, האוטומט יתחיל מהמצב ההתחלתי q0. האות 2 תעביר אותו ל־q1, האות 2 תשאיר אותו ב־q1 בכל המופעים הבאים שלה. מצב מקבל.
\n",
"
דוגמה נוספת
" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "\n", " זוהי דוגמה לקובץ שמתאר את האוטומט המופיע כאן.\n", "
" ] }, { "cell_type": "raw", "metadata": {}, "source": [ "Definitions:\n", "States: s0, s1, s2\n", "Start: s0\n", "Accepting: s0\n", "\n", "Transitions:\n", "s0: 0 -> s0\n", "s0: 1 -> s1\n", "s1: 1 -> s0\n", "s1: 0 -> s2\n", "s2: 0 -> s1\n", "s2: 1 -> s2\n", "\n", "Inputs:\n", "0\n", "0, 1\n", "0, 1, 0\n", "0, 0, 0, 0\n", "0, 1, 1, 1, 1, 1, 0" ] } ], "metadata": { "kernelspec": { "display_name": "Python 3", "language": "python", "name": "python3" }, "language_info": { "codemirror_mode": { "name": "ipython", "version": 3 }, "file_extension": ".py", "mimetype": "text/x-python", "name": "python", "nbconvert_exporter": "python", "pygments_lexer": "ipython3", "version": "3.8.6" } }, "nbformat": 4, "nbformat_minor": 2 }