1 00:00:00,000 --> 00:00:00,500 2 00:00:00,500 --> 00:00:02,500 ZAMYLA چان: یہ ایک، میرے، کیا Zamyla ہے. 3 00:00:02,500 --> 00:00:06,910 ماریو میں آج ہم ہو جا رہے ہیں ماریو کے لئے نصف پرامڈ ڈرائنگ 4 00:00:06,910 --> 00:00:08,290 چڑھنے کے لئے. 5 00:00:08,290 --> 00:00:11,570 >> تو کے بارے میں بات ہمارے اس مسئلہ کے لئے سے کرتے کی. 6 00:00:11,570 --> 00:00:13,610 ہم چاہتے ہیں جا رہے فوری اور درست کرنے 7 00:00:13,610 --> 00:00:18,290 کس طرح ایک درست ان پٹ کے لئے صارف اعلی ماریو پرامڈ بننا چاہتا ہوں. 8 00:00:18,290 --> 00:00:20,090 اور پھر، ہم اسے اپنی طرف متوجہ کرنے کے لئے جا رہے ہیں. 9 00:00:20,090 --> 00:00:24,870 تو فورا ہی ساتھ شروع کرنے کی اجازت نہیں اور ان پٹ کے لئے صارف کی توثیق. 10 00:00:24,870 --> 00:00:27,640 >> ہم کے استعمال کر سکتے ہیں CS50 لائبریری تقریب 11 00:00:27,640 --> 00:00:31,160 اس بات کا یقین کرے گا کہ int حاصل صارف ایک عددی آدانوں. 12 00:00:31,160 --> 00:00:35,730 کوئی مثبت صحیح عدد، منفی integers کے، نمبر 0 تمام منصفانہ کھیل. 13 00:00:35,730 --> 00:00:41,670 دوسری صورت میں، صارف کو کہا جائے گا وہ ان پٹ ایک درست عدد صحیح ہے جب تک دوبارہ کوشش. 14 00:00:41,670 --> 00:00:44,210 اب حاصل INT کرتا ہے اگرچہ ہمارے لئے بہت کام 15 00:00:44,210 --> 00:00:46,730 کو یقینی بنانے میں ہے کہ صارف ہمیں ایک عددی دیتا ہے، 16 00:00:46,730 --> 00:00:50,760 ہم اب بھی کچھ لاگو کرنے کی ضرورت اس پر اضافی رکاوٹوں. 17 00:00:50,760 --> 00:00:56,420 سب کے بعد، ہم ماریو چڑھنے کی ضرورت نہیں کر سکتے ہیں اونچائی منفی 12 کے نصف پرامڈ. 18 00:00:56,420 --> 00:00:59,040 >> اس کے علاوہ، مسئلہ تصریح 19 00:00:59,040 --> 00:01:02,490 کہ ہم صرف کر سکتے ہیں کا کہنا ہے کہ ماریو چڑھنے کی اجازت 20 00:01:02,490 --> 00:01:06,940 0 اور 23 کے درمیان بلندیوں کی ایک پرامڈ. 21 00:01:06,940 --> 00:01:11,120 ٹھیک ہے، تو ہے کہ ہم ضرورت کا مطلب ہے مسلسل صارف کو فوری طور کرنا 22 00:01:11,120 --> 00:01:14,320 ہمیں ایک درست دینے کے لئے نمبر اور صرف جاری رہے 23 00:01:14,320 --> 00:01:17,120 وہ ہمیں ایک درست اونچائی دیا ہے ایک بار. 24 00:01:17,120 --> 00:01:18,720 ہم کہ کس طرح کروں؟ 25 00:01:18,720 --> 00:01:23,760 >> ویسے، مستقل عمل ہمیں دے loops-- کر کچھ کا خیال 26 00:01:23,760 --> 00:01:24,720 بار بار. 27 00:01:24,720 --> 00:01:28,220 تھوڑی دیر کے طور پر سی میں ایک لوپ لوپ کہ مسلسل ہو جائے گا 28 00:01:28,220 --> 00:01:33,480 جب تک کے طور لوپ کے جسم کو پھانسی دی حالت صحیح تشخیص. 29 00:01:33,480 --> 00:01:36,200 جیسے ہی کہ شرط کے طور پر جھوٹے پر تشخیص، 30 00:01:36,200 --> 00:01:39,770 پروگرام پر جاری رہے گی جو کچھ اس کے بعد آتا ہے. 31 00:01:39,770 --> 00:01:43,180 loops کی ایک طریقہ ہیں جبکہ سو ہم اس مسلسل کو یقینی بنانے 32 00:01:43,180 --> 00:01:45,320 ایک درست ان پٹ کے لئے صارف کو فوری طور. 33 00:01:45,320 --> 00:01:50,070 اور ایک بار انہوں نے ہمیں ایک درست ان پٹ کو دے، ہم اگلے آتا ہے جو کچھ بھی کرنے کے لئے کارروائی کر لیں گے. 34 00:01:50,070 --> 00:01:54,380 ہمیں امید ہے کہ ہم آپ سے درخواست کرنے کے لئے جا رہے ہیں جانتے ہیں کم از کم ایک بار ان پٹ کے لئے صارف. 35 00:01:54,380 --> 00:01:59,200 تو اب ہم میں سے ایک بہن کے لئے آیا لوپ، ایسا جبکہ لوپ ہے جس جبکہ. 36 00:01:59,200 --> 00:02:02,650 >> لوپس عملدرآمد کرے گا جبکہ کم از کم ایک بار لوپ کے جسم. 37 00:02:02,650 --> 00:02:06,150 لہذا شرط جانچ پڑتال کے بغیر، یہ لوپ کے جسم پر عمل کریں گے. 38 00:02:06,150 --> 00:02:09,750 اور پھر دیکھنا حالت چیک چاہے وہ خود کو دوبارہ کرنے کی ضرورت ہے. 39 00:02:09,750 --> 00:02:13,080 یہ جب ہاتھ میں آتا ہے ہم صارف کی ان پٹ کی توثیق کر رہے ہیں. 40 00:02:13,080 --> 00:02:15,830 ہمیں امید ہے کہ ہم جا رہے ہیں جانتے ہیں کم از کم ایک بار ان سے پوچھیں کرنے. 41 00:02:15,830 --> 00:02:18,780 چنانچہ ایک کر دیر لوپ شاید کچھ اس طرح نظر. 42 00:02:18,780 --> 00:02:20,090 ہم ایک عددی ن ہے. 43 00:02:20,090 --> 00:02:22,760 اور کرتے کے اندر جبکہ لوپ، ہم فوری طور پر 44 00:02:22,760 --> 00:02:24,750 ایک عددی کے لئے صارف کو فوری طور. 45 00:02:24,750 --> 00:02:29,740 ن غلط ہے تو پھر ہمیں انہیں فوری طور پر لیں گے بار بار بار وہ جب تک 46 00:02:29,740 --> 00:02:31,820 ہمیں یہ درست عدد صحیح دے. 47 00:02:31,820 --> 00:02:37,440 آخر میں، ایک بار ن ایک درست ان پٹ ہے، ہم کریں گے ہمارے پروگرام کے باقی کے لئے آگے بڑھنے. 48 00:02:37,440 --> 00:02:41,830 >> تو چلو رپورٹ اور چیک کرنے کے لئے واپس جانے دو کیا ایک درست ان پٹ کے لئے حالات 49 00:02:41,830 --> 00:02:43,670 ہونے جا رہا ہے. 50 00:02:43,670 --> 00:02:48,090 درست بلندیوں تک جا رہے ہیں 0 اور 23، پر مشتمل ہے کے درمیان ہو. 51 00:02:48,090 --> 00:02:53,350 تو باطل بلندیوں تک جا رہے ہیں 0 سے کم یا 23 سے زیادہ ہو. 52 00:02:53,350 --> 00:02:56,420 تو ڈیزائن کے لئے یاد آپ کی حالت میں احتیاط سے، 53 00:02:56,420 --> 00:02:58,660 شرط یہ ہے کہ یہ جانتے ہوئے کرو جبکہ لوپ کے لئے 54 00:02:58,660 --> 00:03:01,470 ہونا چاہئے جبکہ ن غلط ہے. 55 00:03:01,470 --> 00:03:05,080 اب یہ ایک بننے کے لئے نہیں جا رہا ہے سادہ ایک بولین اظہار. 56 00:03:05,080 --> 00:03:07,630 ہم کو اکٹھا کرنے کی ضرورت کے لئے جا رہے ہیں دو مختلف اظہار 57 00:03:07,630 --> 00:03:09,900 ہمارے پورے شرط بنانے کے لئے. 58 00:03:09,900 --> 00:03:13,290 >> تو صرف میں نے ایک حقیقت کی میز کو دیکھو پہلے سے ہی آپ کو اشارہ ہم ہیں کہ دی 59 00:03:13,290 --> 00:03:15,200 دو Booleans کے ساتھ نمٹنے جا. 60 00:03:15,200 --> 00:03:19,620 تو یہاں ایک حقیقت میز ہے جہاں میں دو Booleans-- بولین 1 اور 2 ہے. 61 00:03:19,620 --> 00:03:27,050 تو ہم اندازہ کرنے کا اختیار ہے bool1 اور bool2 یا bool1 یا bool2. 62 00:03:27,050 --> 00:03:31,980 اور صرف دونوں اگر سچ ہو جائے گا Booleans کے تمام جبکہ، صحیح پر اندازہ 63 00:03:31,980 --> 00:03:37,280 یا ایک کے طور پر طویل عرصے کے طور پر سچ ہو جائے گا دو Booleans کے صحیح تشخیص. 64 00:03:37,280 --> 00:03:41,450 ٹھیک ہے، تو ایک لمحے لے لو، اس کو موقوف ویڈیو اور اس سچائی کی میز ہضم. 65 00:03:41,450 --> 00:03:42,930 میں یہیں انتظار کروں گا. 66 00:03:42,930 --> 00:03:45,760 جب آپ واپس آئیں، دیکھتے ہیں آپ ساتھ مل کر ٹکڑے کر سکتے ہیں تو 67 00:03:45,760 --> 00:03:51,910 کے لئے ایک بولین اظہار آپ ن کی شرط ایک غلط اندراج ہونے کے. 68 00:03:51,910 --> 00:03:54,420 >> تو اب ہم ہے کہ درست صارف ان پٹ، کی اجازت 69 00:03:54,420 --> 00:03:58,710 آگے بڑھو اور ہم کس طرح کے بارے میں بات نصف پرامڈ اپنی طرف متوجہ کر سکتے ہیں. 70 00:03:58,710 --> 00:04:03,410 یہاں اس سادہ ٹیکسٹ ایڈیٹر میں، میں نے ایک بائیں منسلک پرامڈ تیار کی ہے. 71 00:04:03,410 --> 00:04:07,050 لیکن ہم ہمارے ضرورت ہے پرامڈ حق منسلک کیا جائے گا. 72 00:04:07,050 --> 00:04:08,650 تو میں نے ایسا کیسے کر سکتے ہیں؟ 73 00:04:08,650 --> 00:04:11,440 ٹھیک ہے، میں آگے بڑھانے کے لئے کی کوشش کر سکتے ضمنی کے لئے سب کچھ 74 00:04:11,440 --> 00:04:14,880 صرف ایک چھوٹا سا ڈال کی طرف سے درمیان میں کردار. 75 00:04:14,880 --> 00:04:16,779 اور پھر، اگلے کے لئے لکیر، میں ڈال کرنے کے لئے جا رہا ہوں 76 00:04:16,779 --> 00:04:20,970 کچھ زیادہ حروف اس کے ساتھ ساتھ آگے بڑھانے کے لئے، اور further-- اسی اور وغیرہ 77 00:04:20,970 --> 00:04:23,360 میں نے دائیں منسلک پرامڈ ہے جب تک. 78 00:04:23,360 --> 00:04:27,780 تو ہم نے ایک صحیح سیدھ پرامڈ ہے، لیکن یہ نقطے کے ساتھ تو بہت اچھا نظر نہیں آتی. 79 00:04:27,780 --> 00:04:30,680 لیکن ہم اب بھی کرنا چاہتے ہیں وہ اچھا وقفہ کاری کو برقرار رکھنے. 80 00:04:30,680 --> 00:04:35,260 تو میں نے لفظی کرنے جا رہا ہوں کچھ خالی جگہ داخل. 81 00:04:35,260 --> 00:04:39,420 >> تین نقطے کی بجائے، میں کروں گا ایک، دو، تین خالی جگہوں ڈال. 82 00:04:39,420 --> 00:04:40,370 دوسری لائن پر. 83 00:04:40,370 --> 00:04:42,640 میں نے ایک، دو خالی جگہوں ڈال دیتا ہوں. 84 00:04:42,640 --> 00:04:45,370 اور اپانتی پر لکیر، صرف ایک خلائی. 85 00:04:45,370 --> 00:04:48,290 اور یہاں میں ایک دائیں منسلک پرامڈ ہے. 86 00:04:48,290 --> 00:04:52,170 متن میں مثال کرنے سے ایڈیٹر، ہم پیٹرن کے لئے ایک خیال ہے 87 00:04:52,170 --> 00:04:54,590 ہم نصف پرامڈ اپنی طرف متوجہ کرنے کے لئے استعمال کریں گے کہ. 88 00:04:54,590 --> 00:04:58,080 ہر صف کے لئے، ہم نے کیا ہم نے کچھ خالی جگہوں کی قسم ہے، 89 00:04:58,080 --> 00:05:00,170 اور پھر ٹائپ کچھ hashes کو، اور پھر ٹائپ 90 00:05:00,170 --> 00:05:03,020 کلید درج کریں، جس میں ایک نئی سطر پیدا کر رہا ہے. 91 00:05:03,020 --> 00:05:07,770 تو اب ہم اس کے لئے ہے کہ، ہم چلتے ہیں ایک قدم آگے اور ایک پیٹرن کو تلاش کریں. 92 00:05:07,770 --> 00:05:10,170 >> تو میں نے کے لئے، کہنے جا رہا ہوں اس مثال کے مفاد، 93 00:05:10,170 --> 00:05:12,480 ہم 8 کی بلندی کے ساتھ کام کر رہے ہو. 94 00:05:12,480 --> 00:05:17,100 پہلی صف دو کر جا رہا ہے سات خالی جگہوں مندرجہ ذیل ہے کہ ہیشز. 95 00:05:17,100 --> 00:05:20,020 دوسرے کی تین hashes، چھ خالی جگہوں. 96 00:05:20,020 --> 00:05:24,260 تیسری row-- چار ہیشز، پانچ spaces-- تو اور تو آگے 97 00:05:24,260 --> 00:05:26,350 ہم nth صف تک پہنچنے تک. 98 00:05:26,350 --> 00:05:31,540 تو پھر، کیا میں nth صف کے لئے تم سے پوچھنا، ہم کتنے hashes ضرورت کے لئے جا رہے ہیں 99 00:05:31,540 --> 00:05:33,120 اور کتنے خالی جگہوں؟ 100 00:05:33,120 --> 00:05:37,000 تو یہ ایک معلوم کرنا آپ پر منحصر ہے کتنے hashes کی نمائندگی کرنے کے فارمولے 101 00:05:37,000 --> 00:05:42,020 اور کتنے خالی جگہوں کے لئے کی ضرورت ہے آپ کو کچھ اونچائی ہے جب nth صف. 102 00:05:42,020 --> 00:05:46,060 >> اب آپ کو اس باہر figuring کر رہے ہیں جب، احتیاط سے آپ تخکرمن رہے ہیں کس طرح کیا جائے. 103 00:05:46,060 --> 00:05:49,170 کیا میں اس کی طرف سے مطلب ہے کہ روزمرہ کی زندگی ہم سب کے اندر 104 00:05:49,170 --> 00:05:51,540 1 کی طرف سے عام طور پر، گنتی شروع. 105 00:05:51,540 --> 00:05:55,950 لیکن CS50 میں اور کمپیوٹر سائنس میں عام طور پر، ہم 0 حساب سے ترتیب ہیں. 106 00:05:55,950 --> 00:06:00,620 تو سب سے پہلے قطار ہو گی 0 N 1 کے طور پر مخالفت. 107 00:06:00,620 --> 00:06:04,550 تم ہو جب اس کا محتاط رہیں آپ کے پیٹرن پتہ کرنے کی کوشش. 108 00:06:04,550 --> 00:06:07,570 تو اب کس طرح کرنے کے لئے واپس جانے دیا ہم اپنے پرامڈ اپنی طرف متوجہ کرنے کے لئے جا رہے ہیں. 109 00:06:07,570 --> 00:06:12,300 ہر صف کے لئے، ہم کرنا چاہتے ہیں جا رہے ہیں ، خالی جگہوں کو پرنٹ hashes کو پرنٹ، 110 00:06:12,300 --> 00:06:14,050 اور پھر ایک نئی سطر میں پرنٹ. 111 00:06:14,050 --> 00:06:19,160 یہاں اشارہ ہے ہر صف "کے لئے" لفظ. 112 00:06:19,160 --> 00:06:21,470 C میں، ہم نے ایک تعمیر ہے لوپ کے لئے ایک بلایا، 113 00:06:21,470 --> 00:06:25,250 ایک پر مشتمل ہے جس میں ابتدا، حالت، ایک اپ ڈیٹ، 114 00:06:25,250 --> 00:06:26,790 اور لوپ کے جسم. 115 00:06:26,790 --> 00:06:31,360 >> میں کہنا چاہتا تھا ہیلو کہو دنیا، 50 مرتبہ، میری لوپ کے لئے 116 00:06:31,360 --> 00:06:32,880 کچھ اس طرح نظر آئے گا. 117 00:06:32,880 --> 00:06:35,480 میں 0 کے لئے اپنی عددی ابتدا. 118 00:06:35,480 --> 00:06:38,230 شرط میں نے 50 سے بھی کم ہے کہ ہے. 119 00:06:38,230 --> 00:06:42,350 اور پھر میری ید صرف ہے ایک ہر وقت تک میں نے incrementing کی. 120 00:06:42,350 --> 00:06:45,140 ہم نے بھی loops کے لئے استعمال کر سکتے ہیں چیزوں پر iterate. 121 00:06:45,140 --> 00:06:47,820 یہاں نوٹس ہمیں نہیں دیکھا کہ مشکل، ایک بڑی تعداد کوڈت 122 00:06:47,820 --> 00:06:51,820 بلکہ متغیر رکھ دیا بجائے حالت میں اونچائی. 123 00:06:51,820 --> 00:06:56,420 تو میں یہاں کیا کر رہا ہوں میں iterating رہا ہوں کیا ہے پرامڈ کے ہر تنازعہ پر. 124 00:06:56,420 --> 00:07:00,160 میں نے ہر ایک کے لئے کچھ کر سکتے ہیں میرے لوپ کے جسم کے اندر قطار. 125 00:07:00,160 --> 00:07:02,350 >> ہم اندر کیا کر رہے ہیں لوپ کے جسم؟ 126 00:07:02,350 --> 00:07:07,120 ویسے، ہم نے پہلے ہی کہا تھا کہ ہم چھپائی رہے ہیں خالی جگہوں اور ہم hashes کو چھپائی رہے ہیں 127 00:07:07,120 --> 00:07:09,480 اور ہم نے ایک نئی لائن چھپائی رہے ہیں. 128 00:07:09,480 --> 00:07:11,950 تو لوپ کے لئے اپنے بیرونی اس طرح نظر آئے گا. 129 00:07:11,950 --> 00:07:15,070 میں نے ہر صف پر iterate پرامڈ کے، کا استعمال کرتے ہوئے، 130 00:07:15,070 --> 00:07:18,890 اس صورت میں، متغیر کے طور پر اونچائی کہ پرامڈ کے عروج ذخیرہ ہے. 131 00:07:18,890 --> 00:07:22,870 اس لوپ کے جسم کے اندر، میں ہوں بار بار خالی جگہوں کو پرنٹ کرنے کے لئے جا، تعداد 132 00:07:22,870 --> 00:07:26,730 بار بار hashes کو، اور پھر ایک نئی سطر میں پرنٹ. 133 00:07:26,730 --> 00:07:31,010 >> تو اب، تصورات کے تمام کا استعمال کرتے ہوئے میں نے اس واک کے ذریعے میں کے بارے میں بات کی ہے 134 00:07:31,010 --> 00:07:35,210 آپ فوری طور پر کرنے کے قابل ہونا چاہئے صارف کی ان پٹ کے لئے،، کہ ان پٹ کی توثیق 135 00:07:35,210 --> 00:07:37,370 اور پھر نصف پرامڈ اپنی طرف متوجہ. 136 00:07:37,370 --> 00:07:41,510 >> میرا نام Zamyla ہے، اور اس CS50 ہے. 137 00:07:41,510 --> 00:07:43,167