1 00:00:00,000 --> 00:00:00,930 2 00:00:00,930 --> 00:00:04,030 >> Zamyla צ'אן: בואו להגביר את שלנו משחק עם צופן ויז'נר. 3 00:00:04,030 --> 00:00:06,710 צופן ויז'נר הוא דומה מאוד קיסר, 4 00:00:06,710 --> 00:00:11,060 למעט קיסר עברנו ב שלם אחד כמפתח שלנו. 5 00:00:11,060 --> 00:00:14,100 בשנת vigenere אנחנו הולכים לעבור את מילת המפתח. 6 00:00:14,100 --> 00:00:19,400 אז, אם אני רוצה להעביר את המוצפן הזה הוא 50 CS ידי ohai, 7 00:00:19,400 --> 00:00:23,260 אז זה אומר כי כל אות ohai הולך לשרת כמפתח, 8 00:00:23,260 --> 00:00:27,160 ואני הולך מחזור מעל כי מילת המפתח עבור המשמרת שלי 9 00:00:27,160 --> 00:00:31,930 מה שהופך את המוצפן הרבה יותר קשה לפענח. 10 00:00:31,930 --> 00:00:34,540 >> מה זה אומר משמרת ידי מילת המפתח? 11 00:00:34,540 --> 00:00:38,610 ובכן, מילת המפתח היא מחרוזת איפה כל אות תואמת 12 00:00:38,610 --> 00:00:41,080 לכמה משמרת שלמה. 13 00:00:41,080 --> 00:00:49,310 לכן, o מתאים מפתח של 14, h למקש של 7, יש מפתח של 0, 14 00:00:49,310 --> 00:00:54,670 כך לא הייתי משנה דבר, יש ואז אני מפתח של 8. 15 00:00:54,670 --> 00:01:00,000 >> תגיד רצתי vigenere עם טקסט רגיל זה גם CS50, 16 00:01:00,000 --> 00:01:02,800 זה היה פשוט לתת לי מחרוזת ללא שינוי. 17 00:01:02,800 --> 00:01:08,170 שימו לב כי זה שווה פועל קיסר עם מפתח של אפס. 18 00:01:08,170 --> 00:01:12,070 למעשה, פועל vigenere עם כל תו בודד 19 00:01:12,070 --> 00:01:17,070 יהיה שווה ריצה קיסר עם אותו שלם. 20 00:01:17,070 --> 00:01:20,400 >> בסדר, אז, מאז הם כל כך דומים הייתי 21 00:01:20,400 --> 00:01:24,300 למעשה ממליץ שאם אתה רוצה אתה יכול פשוט להעתיק הקיסר שלך 22 00:01:24,300 --> 00:01:26,932 קוד לקוד vigenere שלך. 23 00:01:26,932 --> 00:01:28,640 דברים ישתנו, אבל לפחות יש לך 24 00:01:28,640 --> 00:01:31,110 עמוד שדרה כמה שאתה יכול לעבוד איתו. 25 00:01:31,110 --> 00:01:36,410 מכיוון Todos זהה שאנחנו רוצים כדי לקבל את המפתח, לקבל את הטקסט הרגיל, 26 00:01:36,410 --> 00:01:40,690 לְקַדֵד כי טקסט רגיל, ואז להדפיס את זה. 27 00:01:40,690 --> 00:01:44,980 >> בדיוק כמו קיסר המפתח הוא הולך יועבר ב משורת הפקודה השנייה 28 00:01:44,980 --> 00:01:50,540 טיעון כלול במדד argv 1, אבל זה שונה הפעם 29 00:01:50,540 --> 00:01:52,560 כי זה חייב להיות אלפביתי. 30 00:01:52,560 --> 00:01:56,390 אז, אנחנו צריכים לחזר על כל תו בודד באותה מפתח 31 00:01:56,390 --> 00:02:00,800 שהמשתמש עבר, ולהבטיח שכל דמות היא האלפביתי 32 00:02:00,800 --> 00:02:02,800 על מנת להמשיך. 33 00:02:02,800 --> 00:02:05,560 >> ברגע שעשינו את זה, אז אנחנו יכול לקבל את מחרוזת מהמשתמש, 34 00:02:05,560 --> 00:02:07,560 בדיוק כפי שעשינו בעבר. 35 00:02:07,560 --> 00:02:10,520 ועכשיו, אנחנו מגיעים ללב הבעיה עבור vigenere, 36 00:02:10,520 --> 00:02:14,665 וזה בדיוק כמו קיסר, איך להבין את דפוס ההצפנה 37 00:02:14,665 --> 00:02:19,760 ומשוואה, ו לְקַדֵד בטקסט כולו. 38 00:02:19,760 --> 00:02:23,280 >> אז, תבחין כי המשוואה עבור משמרת vigenere 39 00:02:23,280 --> 00:02:25,610 הוא מאוד דומה לזו קיסר. 40 00:02:25,610 --> 00:02:29,780 ההבדל היחיד הוא כי במקום k משתנה בודד 41 00:02:29,780 --> 00:02:37,270 לפני, עכשיו k יש פירוט, המציין את המכתב JTH של המפתח. 42 00:02:37,270 --> 00:02:39,560 >> בואו נבחן דוגמה. 43 00:02:39,560 --> 00:02:43,830 נניח שאתה רוצה להעביר סוד הודעה על מושא אהבתך, אני מחבב אותך. 44 00:02:43,830 --> 00:02:46,325 ובכן, עבור המפתח שלך אתה לבחור משהו שלך 45 00:02:46,325 --> 00:02:49,790 למעוך יודע יודע שאתה אוהב, פנדות. 46 00:02:49,790 --> 00:02:52,290 בסדר, אז איך אנחנו להעביר את זה? 47 00:02:52,290 --> 00:02:55,500 >> ובכן, יש לנו מדד בטקסט שלנו. 48 00:02:55,500 --> 00:02:59,160 זה במכתב הראשון כך הוא המדד בגין המפתח שלנו 49 00:02:59,160 --> 00:03:02,830 שנמצא בחלק p, הראשון מכתב במילה פנדה שלנו. 50 00:03:02,830 --> 00:03:08,590 אז, הסטה לי על ידי p נותן לנו x, אז אנחנו מתקדמים המדד בטקסט. 51 00:03:08,590 --> 00:03:10,460 זה מגיע לנו מרחב. 52 00:03:10,460 --> 00:03:13,540 עכשיו, תו הרווח הוא אלפביתי עישון, 53 00:03:13,540 --> 00:03:16,930 כך אומר, כי רק העברות ישר אל המוצפן, 54 00:03:16,930 --> 00:03:23,430 שמנו מרחב שם, ואנחנו לא לקדם את מדד המפתח שלנו. 55 00:03:23,430 --> 00:03:25,820 אז, אנחנו עדיין בעמ בנקודה זו. 56 00:03:25,820 --> 00:03:30,130 >> אנו להתקדם הבאים מדד בטקסט שלנו. 57 00:03:30,130 --> 00:03:34,030 ועכשיו, כי זה מכתב, את L הקטנה, 58 00:03:34,030 --> 00:03:37,920 אנחנו משמרת שעד המדד הבא המפתח שלנו. 59 00:03:37,920 --> 00:03:42,360 איזו מהאפשרויות הבאות היא, שהוא אפס משמרת כך פשוט הופך 60 00:03:42,360 --> 00:03:44,370 האות L ב המוצפן שלנו. 61 00:03:44,370 --> 00:03:51,120 לאחר מכן, אנו לקדם הן בטקסט, ו מדד המפתח כי זה האלפביתי. 62 00:03:51,120 --> 00:03:56,210 אז נמשיך כי עד שנגיע אל הדואר ב וכדומה. 63 00:03:56,210 --> 00:04:01,090 >> בסדר, אז תבחין בזה בשלב זה, במונחים של מדד המפתח שלנו, 64 00:04:01,090 --> 00:04:03,940 הגענו סוף מילת פנדה, אז מה 65 00:04:03,940 --> 00:04:08,750 קורה כשנגיע לשלב הבא מכתב האלפביתי ב בטקסט? 66 00:04:08,750 --> 00:04:12,180 ובכן, כל מה שקורה הוא שאנחנו לעטוף אל ההתחלה, 67 00:04:12,180 --> 00:04:14,710 למדד הראשון של המפתח שלנו. 68 00:04:14,710 --> 00:04:19,570 אז, אז אנחנו משמרים כי y על ידי p לתת לנו n. 69 00:04:19,570 --> 00:04:26,860 ואז, אנו ממשיכים גמר קידוד בטקסט שלנו כדי לקבל נוה x lvne. 70 00:04:26,860 --> 00:04:29,300 >> מתוך דוגמה זו, אני הראה כי אנו רק לקדם 71 00:04:29,300 --> 00:04:33,140 למכתב הבא מילת המפתח אם הדמות בטקסט רגיל 72 00:04:33,140 --> 00:04:37,480 מכתב הוא כך isalpha פונקציה תגיע שימושי כאן. 73 00:04:37,480 --> 00:04:43,030 וזה, בדיוק כמו קיסר, אנחנו רוצים לשמר את המקרה, isupper ו islower. 74 00:04:43,030 --> 00:04:46,100 אז, להוסיף קצת זה ב לתוך פסאודו הקוד שלך. 75 00:04:46,100 --> 00:04:48,510 >> אז איך אנחנו להבין את משמרות מפתח? 76 00:04:48,510 --> 00:04:53,030 ובכן, אם אתה זוכר את הדיון שלנו על מדדי אלפביתי של הקיסר 77 00:04:53,030 --> 00:04:55,370 בעיה, זה מאוד דומה. 78 00:04:55,370 --> 00:05:01,130 >> שם מקבילה ASCII ערך של 65 אבל שינוי של 0, 79 00:05:01,130 --> 00:05:03,550 ואז את האות האחרונה באלפבית, Z, 80 00:05:03,550 --> 00:05:06,940 מתאים משמרת של 25. 81 00:05:06,940 --> 00:05:10,320 תוכל להבחין כי המעבר זהה אם לא 82 00:05:10,320 --> 00:05:14,880 המכתב הוא במקרה גדול או קטן. 83 00:05:14,880 --> 00:05:17,700 >> אוקיי, אז עכשיו אתה יודע איך להבין 84 00:05:17,700 --> 00:05:21,470 משמרת מספרים מתאים תו בודד 85 00:05:21,470 --> 00:05:24,050 בואו נחזור למשוואה שלנו. 86 00:05:24,050 --> 00:05:28,180 כי יש לנו שתי שונים תחתי כאן, i ו j, 87 00:05:28,180 --> 00:05:32,130 זה רמז כי אנחנו רוצים לעקוב אחר הוא מעמדנו בטקסט 88 00:05:32,130 --> 00:05:36,600 כמו גם את מעמדנו מילת המפתח, אז אלו הם שני משתנים נפרדים 89 00:05:36,600 --> 00:05:39,010 כי אנחנו רוצים לשמור על אחיזה של. 90 00:05:39,010 --> 00:05:42,580 >> עכשיו, את המיקום בטקסט שלנו הוא הולך לגדול בכל פעם, 91 00:05:42,580 --> 00:05:45,530 כך זה הולך להיות קצת יותר ישר קדימה 92 00:05:45,530 --> 00:05:49,750 בניגוד לעמדת מילת המפתח, אשר אנו יודעים יש לעטוף, 93 00:05:49,750 --> 00:05:52,910 ולפעמים להגדיל, לפעמים נשאר אותו הדבר. 94 00:05:52,910 --> 00:05:55,430 אז, איך אנו מקיימים הפונקציונלי 95 00:05:55,430 --> 00:05:59,820 כדי לעטוף את מדד עבור מילת המפתח? 96 00:05:59,820 --> 00:06:01,640 >> אני הולך להשתמש התפקדתי למשל. 97 00:06:01,640 --> 00:06:06,100 פִּקוּדִים היא דרך פופולרית לפצל אנשים לקבוצות. 98 00:06:06,100 --> 00:06:10,660 שאצהיר 5 אנשים ורציתי לפצל אותם לשלוש קבוצות, 99 00:06:10,660 --> 00:06:13,640 גם אז הייתי מתחיל ידי פִּקוּדִים. 100 00:06:13,640 --> 00:06:16,980 האדם הראשון היה צוות אומר אני מספר אחד, 101 00:06:16,980 --> 00:06:21,030 האדם הבא יהיה מספר קבוצה שני, מספר צוות בגוף שלישי 102 00:06:21,030 --> 00:06:21,910 שְׁלוֹשָׁה. 103 00:06:21,910 --> 00:06:25,910 עכשיו, אני רוצה רק שלוש קבוצות כל כך האדם הרביעי היה למעשה 104 00:06:25,910 --> 00:06:30,160 נתחיל בהתחלה ולומר, טוב, אני מספר קבוצה אחת וכן, 105 00:06:30,160 --> 00:06:32,890 והאדם הבא יהיה מספר הקבוצה שני. 106 00:06:32,890 --> 00:06:37,660 וגם, ומשם, לאחר מכן הם יכולים להפריד לקבוצות שלהם. 107 00:06:37,660 --> 00:06:41,130 >> אז, איך יכול אני משתמש מודולו כדי לעזור לי ליישם 108 00:06:41,130 --> 00:06:44,160 זה התפקד לעטוף סביב פונקציה? 109 00:06:44,160 --> 00:06:50,140 ובכן, האדם הראשון מספר 1, mod 3 נותן לנו 1. 110 00:06:50,140 --> 00:06:54,690 2 mod 3 נותן לנו 2, ו -3 mod 3 נותן לנו 0. 111 00:06:54,690 --> 00:07:02,140 >> האדם הרביעי, מספר 4, 3 mod נותן לנו 1, ולאחר מכן 5 mod 3 נותן לנו 2. 112 00:07:02,140 --> 00:07:05,370 אז, תוכל להבחין כי למרות מספר האנשים שיש לי 113 00:07:05,370 --> 00:07:11,210 מגדילה, והוא מעל 3, מאז אני modding ידי 3 114 00:07:11,210 --> 00:07:15,250 אני תמיד מקבל מספרים 0, 1, ו -2. 115 00:07:15,250 --> 00:07:19,040 אני אף פעם לא גדול מ -3. 116 00:07:19,040 --> 00:07:22,630 אז, גם אם היה לי 10 אנשים, אז כל האנשים האלה 117 00:07:22,630 --> 00:07:27,430 עדיין יהיה בתוך קבוצות 1, 2, או 0. 118 00:07:27,430 --> 00:07:33,560 >> אז, עכשיו אנחנו יודעים שאם יש לנו קבוצה 5 ואנחנו mod כל אלה על ידי 3, 119 00:07:33,560 --> 00:07:38,180 אז אנחנו אף פעם לא הולכים תעלה קבוצות 0, 1, או 2. 120 00:07:38,180 --> 00:07:43,430 אז, אנחנו אף פעם לא הולכים לקבל קבוצה מספר זה שווה 3 ומעלה. 121 00:07:43,430 --> 00:07:46,980 לכן, גם אם אני מוסיף עוד חמש אנשים, אז כולם 122 00:07:46,980 --> 00:07:53,150 עדיין יהיה שהוקצו לקבוצות 0, 1, או 2 כי אני modding ידי 3. 123 00:07:53,150 --> 00:07:56,510 ואני לא מתכוון לחרוג כובע זה. 124 00:07:56,510 --> 00:08:00,800 >> אוקיי, אז בוא נראה אם ​​נוכל ליישם תפיסה זו של שימוש מודולו 125 00:08:00,800 --> 00:08:03,710 כדי לעטוף את מספרי קבוצה ולהחיל 126 00:08:03,710 --> 00:08:08,000 אותו vigenere לאן שאנחנו רוצים להשתמש מודולו כדי לעטוף 127 00:08:08,000 --> 00:08:10,220 המדד עבור מילת המפתח. 128 00:08:10,220 --> 00:08:12,830 למרות שאנחנו הגדלת המדד אנחנו תמיד 129 00:08:12,830 --> 00:08:17,260 רוצה לוודא כי תמיד אנחנו לעטוף לתחילת מאוד 130 00:08:17,260 --> 00:08:20,050 לא יעלה על אורך החוט. 131 00:08:20,050 --> 00:08:23,510 >> אוקיי, אז אני יודע שזה יכול להיות קצת מוחץ. 132 00:08:23,510 --> 00:08:26,670 יש עוד הרבה מה לעשות סט p זה. 133 00:08:26,670 --> 00:08:30,050 לכן, ודא כי אתה כותב את פסאודו קוד טוב בעצמך 134 00:08:30,050 --> 00:08:32,870 שאתה מבין שמקבל את העבודה. 135 00:08:32,870 --> 00:08:35,580 נסו להתייחס לכל שורה אחת באופן עצמאי 136 00:08:35,580 --> 00:08:38,370 להבין את כל המעט חתיכות קטנות של פאזל 137 00:08:38,370 --> 00:08:40,260 לפני שמכניסים אותו יחד. 138 00:08:40,260 --> 00:08:43,110 >> ודא שאתה יכול לקבל המפתח משורת הפקודה 139 00:08:43,110 --> 00:08:46,780 ולהבטיח שזה האלפביתי, לקבל את הטקסט הרגיל מהמשתמש, 140 00:08:46,780 --> 00:08:51,010 ולאחר מכן ב הצפנה, הקפד יודע איך להצפין אות אחת, 141 00:08:51,010 --> 00:08:56,130 ולאחר מכן להתקדם אל השלם מחרוזת עם כל לעטוף פונקציות. 142 00:08:56,130 --> 00:08:59,610 לבסוף, אתה יכול להדפיס את ההודעה המוצפנת. 143 00:08:59,610 --> 00:09:04,050 >> שמי הוא Zamyla, וזה היה vigenere. 144 00:09:04,050 --> 00:09:07,757