الگوریتم ها
در نمایش آنلاین پاورپوینت، ممکن است بعضی علائم، اعداد و حتی فونتها به خوبی نمایش داده نشود. این مشکل در فایل اصلی پاورپوینت وجود ندارد.
- جزئیات
- امتیاز و نظرات
- متن پاورپوینت
الگوریتم ها
اسلاید 1: فصل 1Algorithm الگوریتم هاهدفهاي كلي: شناخت حل مسئله و ارائه الگوریتم شناخت اجزاء لازم برای حل مسئله بررسی صحت الگوریتم
اسلاید 2: هدفهاي رفتاري الگوریتمی را برای حل مسئله ارائه دهد. الگوریتم های مختلف برای یک مسئله را مقایسه کند. شرط ها و حلقه ها را در الگوریتم بکار ببرد . دانشجو پس از مطالعه اين فصل بايد بتواند:
اسلاید 3: تعريف الگوريتم الگوريتم مجموعهاي از دستورالعمل ها، براي حل مسئله ميباشد كه شرايط زير را بايد دارا باشد: دقيق باشد جزئيات كامل حل مسئله را داشته باشد. پايانپذير باشد.
اسلاید 4: مقدمه در زندگي روزمره، انسان با مسائل مختلفي روبروست و براي هر كدام از اين مسائل (حل مشكلات) راه حلي و روشي را بر ميگزيند. مسائلی از قبيل راه رفتن، غذا خوردن، خوابيدن و غيره كه بشر تقريباً هر روز آنها را پيش روي خود دارد.همه اين مسائل نياز به روشي براي حل كردن دارند مثلا راه رفتن بايد با ترتيب خاصي و مراحل معيني انجام شود. تا مسئله راه رفتن براي بشر حل شود. اصطلاحاً روش انجام كار يا حل مسئله را الگوريتم آن مسئله مينامند
اسلاید 5: مراحل الگوريتم براي حل يك مسئله بايد الگوريتم آن مسئله را مشخص كنيم (يا بيابيم) كه اصطلاحاً طراحي الگوريتم براي آن مسئله ناميده ميشود. در طراحي الگوريتم معمولاً سه مرحله زير را از هم جدا ميكنند: خواندن دادهها انجام محاسبات خروجيها
اسلاید 6: مثال :الگوريتمي بنويسيد كه دو عدد از ورودي دريافت كرده مجموع دو عدد را محاسبه و چاپ نمايد. خروجيها انجام محاسبات وروديها مجموع دو عدد جمع دو عدد a , b شروع b ,a را بخوان.مجموع b , a را محاسبه و در sum قرار بده.sum را در خروجي چاپ كن پايان
اسلاید 7: خروجيها انجام محاسبات وروديها چاپ مجموع محاسبه مجموع a چاپ ميانگين محاسبه ميانگين b c مثال: الگوريتمي بنويسيد كه سه عدد از ورودي دريافت كرده مجموع و ميانگين سه عدد را محاسبه و چاپ كند. شروع سه عدد از ورودي بخوان مجموع سه عدد را محاسبه و در Sum قرار بده.Sum را بر سه تقسيم كرده،در Ave قرار بده.Ave , Sum را در خروجي چاپ كن. پايان.
اسلاید 8: معمولا درك يك الگوريتم با شكل راحتر از نوشتن آن بصورت متن ميباشد. لذا الگوريتم را با فلوچارت(flowchart)نمايش ميدهند. فلوچارت از شكلهاي زير تشكيل ميشود.Begin شروعخاتمهEndخواندن Readچاپ کردن write علامتهاي شروع و پايان: كه معمولا از يك بيضي استفاده ميكنند: علامتهاي ورودي و خروجي: كه معمولا از متوازيالاضلاع استفاده ميشود:
اسلاید 9: علامتهاي محاسباتي و جايگزيني: براي نمايش دستورات جايگزيني و محاسباتي از مستطيل استفاده ميكنند:جایگزین یا محاسبات علامت شرط: براي نمايش شرط از لوزي استفاده ميشود. علامت اتصال: براي اتصال شكلهاي مختلف بهم از فلشهاي جهتدار استفاده ميكنند.
اسلاید 10: BeginRead(a,b,c)Sum a+b+cAve sum/3Write(sum,ave)Endفلوچارت مجموع سه عدد
اسلاید 11: مثال: فلوچارتی رسم نمائيد كه دو عدد از ورودي دريافت كرده سپس محتويات دو عدد را با هم جابجا نمايد.براي حل اين مسئله b , a را دو متغير كه در آنها دو عدد خوانده شده، قرار ميگيرند در نظر ميگيريم. سپس با استفاده از يك متغير كمكي محتويات اين دو عدد را جابجا ميكنيم :
اسلاید 12: 1215temptempab121512abtemp151512abtemp151212abtemp
اسلاید 13: BeginRead(a,b)temp aa bWrite(a,b)Endb tempفلوچارت مسئله بالا بصورت زير خواهد بود:
اسلاید 14: تمرين1ـ فلوچارتي رسم نمائيد كه طول و عرض مستطيل را از ورودي دريافت كرده محيط و مساحت آنرا محاسبه و چاپ كند.2ـ فلوچارتي رسم نمائيد كه شعاع دايرهاي را از ورودي دريافت كرده، محيط و مساحت آنرا محاسبه و چاپ نمايد.3ـ فلوچارتي رسم كنيد كه سه عدد Third , second, first را از ورودي دريافت كرده، محتويات آنها را جابجا نموده، حاصل را در خروجيچاپ كند.
اسلاید 15: 4ـ فلوچارتي رسم نمائيد كه دو عدد از ورودي دريافت كرده، سپس محتويات دو عدد را بدون استفاده از متغير كمكي جابجا كند.5ـ فلوچارتي رسم نمائيد كه عددي (درجه حرارت برحسب سانتيگراد) را از ورودي دريافت كرده سپس آنرا به درجه فارنهايت تبديل كند.
اسلاید 16: دستورالعملهاي شرطي در حل بسياري از مسائل يا تقريباً تمام مسائل نياز به استفاده از شروط جزء، نيازهاي اساسي محسوب ميشود. همانطور كه ما خودمان در زندگي روزمره با اين شرطها سركار داريم. بطور مثال اگر هوا ابري باشد ممكن است چنين سخن بگوييم: اگر هوا باراني باشد سپس چتري برميدارم. در غير اينصورت چتر برنميدارم.
اسلاید 17: در حالت كلي شرط را بصورت زير نمايش ميدهند:If شرط یا شروط thenعمل يا اعمال yes NOعمل يا اعمال بعدي
اسلاید 18: مثال : فلوچارتي رسم نمائيد كه عددي را از ورودي دريافت كرده، فرد يا زوج بودن آن را تشخيص دهد.BeginRead(a)R a mod 2Write(‘odd’)Endif R=0 thenNoyesWrite(‘even’)
اسلاید 19: BeginRead(a,b)max a Write(max)Endif b>maxNoyes max bمثال : فلوچارتي رسم كنيد كه دو عدد از ورودي دريافت كرده بزرگترين عدد را پيدا كرده در خروجي چاپ نمايد.
اسلاید 20: BeginRead(a,b,c)min a Write(min)Endif b<min thenNoyesmax bif c<min thenyesmin c Noمثال : فلوچارتي رسم نمائيد كه سه عدد از ورودي دريافت كرده، كوچكترين عدد را يافته در خروجي چاپ نمايد:
اسلاید 21: نمونه اجراي فلوچارت بالا بصورت زير ميباشد:
اسلاید 22: تمرين1- فلوچارتي رسم كنيد که عددي را از ورودي دريافت كرده، قدر مطلق عدد را در خروجي چاپ كند.2- فلوچارتي رسم نمائيد كه عددي از ورودي دريافت كرده مثبت، منفي يا صفر بودن عدد را تشخيص داده، در خروجي با پيغام مناسب چاپ كند.3- فلوچارتي رسم نمائيد كه عددي را از ورودي دريافت كرده، بخشپذيري آن بر 3 و 5 را بررسي نمايد.4ـ فلوچارتي رسم نمائيد كه ضرايب يك معادله درجه دوم را از ورودي دريافت كرده، ريشههاي آن را محاسبه در خروجي چاپ كند.
اسلاید 23: حلقههادر حل بسياري از مسائل با عملياتي روبرو ميشويم ، كه نياز به تكرار دارند و عمل تكرار آنها به تعداد مشخصي انجام ميگيرد. فرض كنيد، بخواهيم ميانگين 100 عدد را محاسبه كنيم، در اينصورت منطقي بنظر نميرسد كه 100 متغير مختلف را از ورودي دريافت كنيم سپس آنها را جمع كنيم.
اسلاید 24: انواع حلقه هاحلقه های با تکرار مشخصحلقه های با تکرار نا مشخص
اسلاید 25: حلقه های با تکرار مشخصدر اين نوع حلقهها تعداد تكرار مشخص ميباشد اين حلقه از اجزاء زير تشكيل ميشود:1ـ انديس حلقه 2ـ مقدار اوليه براي انديس حلقه 3- مقدار افزاينده براي انديس حلقه (معمولا يك واحد در هر مرحله)4ـ مقدار نهايي (تعداد تكرا حلقه)5ـ شرطي براي كنترل تعداد تكرار حلقه
اسلاید 26: i 1 if i<=n yesNoمجموعه دستورات حلقه i i+1اتمام كار حلقه اين حلقهها را غالباً با فلوچارت بصورت زير نمايش ميدهند:
اسلاید 27: مثال : فلوچارتي رسم نمائيد كه عدد n را از ورودي دريافت كرده، مجموع اعداد از يك تا n را محاسبه كند.i انديس حلقه n مقدار نهايي
اسلاید 28: BeginRead(n)I 1 sum 0if I<=nyesNoWrite(sum)Endsum sum+II I+1حلقه
اسلاید 29: نمونه اجراي فلوچارت بالا بصورت زير است:
اسلاید 30: مثال : فلوچارتي رسم كنيد كه n عدد از ورودي دريافت كرده، بزرگترين مقدار از بين n عدد را پيدا كرده در خروجي چاپ نمايد.انديس حلقه iمقدار نهايي nبزرگترين مقدار Max
اسلاید 31: BeginI 2 max a if i<=n thenyesNowrite(max)Endi i+1حلقهRead(a)Read(n)if a > maxmax aNoyes
اسلاید 32: مثال : فلوچارتي رسم نمائيد كه n , x ، دو عدد صحيح مثبت را از ورودي دريافت كرده سپس x به توان n را محاسبه كند.انديس حلقه iمقدار نهايي nعدد به توان n pow
اسلاید 33: Begini 1 pow 1 if i<=n thenyesNowrite(pow)Endpow pow*xحلقهRead(n,x)i i+1
اسلاید 34: حلقههايي كه تعداد تكرار آنها مشخص نيست (در پاسكال به حلقه while مشهورند.)در اين حلقهها با توجه به ورودي، تعداد تكرار مشخص ميشود. و دقيقاً نميتوان تعداد تكرار حلقه را بدون ورودي معين كرد. اين حلقه ها فقط شامل شرطي هستند كه تا زمانيكه برقرار باشد حلقه اجرا ميشود.
اسلاید 35: If شرط يا شروطمحموعه دستورالعملها و جاگزينها yesNoدر حالت كلي اين نوع حلقهها بصورت زير نمايش داده ميشوند:
اسلاید 36: مثال: فلوچارتي رسم كنيد كه عددي را از ورودي دريافت كرده سپس تعداد ارقام آن را شمرده در خروجي چاپ نمايد.عدد خوانده شده N تعداد ارقام count
اسلاید 37: Begincount 0 if N>0 thenyesNowrite(count)EndN N div 10حلقهRead(N)count count+1
اسلاید 38: مثال : فلوچارتي رسم نمائيد كه عددي از ورودي دريافت كرده، سري فيبوناچي قبل از آنرا توليد نمايد.در حالت كلي جملات سري بصورت:fk=fk-1+fk-2عدد خوانده شدهNجمله سوم سري f3جمله دوم سري f2جمله اول سري f1
اسلاید 39: BeginF1 0f2 1 if f3>N thenyesNoEndحلقهRead(N)f1 f2f2 f3f3 f1+f2f3 f1+f2 write(f3)
اسلاید 40: تمرين 1- فلوچارتي رسم نمائيد كه عددي از ورودي دريافت كرده، كامل بودن آنرا بررسي نمايد. (عدد كامل، عددي است كه مجموع مقسومعليههاي آن با خودش برابر باشد.)2- فلوچارتي رسم كنيد كه N را از ورودي دريافت كرده، N جمله سري فيبوناچي را توليد نماید.3ـ فلوچارتي رسم نمائيد كه دو عدد N , M را از ورودي خوانده، بزرگترين مقسومعليه مشترك دو عدد را محاسبه و چاپ كند.
اسلاید 41: حلقههاي تودرتو الگوريتمهايي كه تا حال بكار برديم، فقط شامل يك حلقه بودند.در صورتي كه در بسياري از مسائل ممكن است نياز به استفاده از چندحلقه در داخل هم باشيم. در اين نوع حلقهها بايد دقت بيشتري به خرج دهيم، تا مشكلي پيش نيايد. اگر از حلقههاي نوع اول بصورت تودرتو استفاده كنيم در اينصورت براي هر حلقه شرط نهايي و انديس اوليه جداگانه بايد تعريف كنيم .
اسلاید 42: در حلقههاي تودرتو به ازاي يكبار تكرار حلقه اوليه، حلقه داخلي به اندازه مقدار نهايي خود تكرار ميشود. در كل اگر حلقه اوليه n بار تكرار شود و حلقه داخلي m بار، در اينصورت كل حلقه : بار تكرار خواهد شد.
اسلاید 43: فلوچارت حلقههاي تودرتو را ميتوان بصورت زير نشان داد:i 1 if j<=m thenNoحلقهj j+1yes...if i<=n thenj 1مجموعه دستورات و جايگزيني ها مجموعه دستورات و جايگزيني ها i i+1AAyesNoاتمام كار حلقه هاي تو در تو
اسلاید 44: انديس حلقه اول I ورودي N محاسبه فاكتوريل fact انديس حلقه داخلي j مجموع Sum مثال : فلوچارتي رسم نمائيد كه N را از ورودي دريافت كرده، مجموع سري زير را محاسبه نمايد:
اسلاید 45: i 2sum 1 Aif j<=i Nofact fact*jyesif i<=N fact 1j 2i i+1yesNoRead(N)Endsum sum+i/factAj j+1Write(sum)
اسلاید 46: تمرينات آخر فصل1- فلوچارتي رسم نمائيد كه N عدد از ورودي دريافت كرده تعداد اعداد اول و كامل را شمرده در خروجي چاپ نمايد.2- فلوچارتي رسم نمائيد كه N , X را از ورودي خوانده مقدار سري زير را محاسبه كند:
اسلاید 47: 3- فلوچارتي رسم نمائيد كه عددی را از ورودي دريافت كرده مقلوب عدد را محاسبه و در خروجي چاپ كند.4ـ فلوچارتي رسم كنيد كه تاريخ تولد شخصي را از ورودي خوانده، سن شخص را با تاريخ روز، محاسبه نموده در خروجي چاپ كند.5- فلوچارتي رسم نمائيد كه (m>n) N ,M را از ورودي دريافت كرده سري فيبوناچي بين N ,M را توليد كرده، در خروجي چاپ كند.
اسلاید 48: فصل 2كاربرد آرايه ها در الگوريتم ها هدفهاي كليشناخت الگوریتم های لازم برای جستجو و مرتب سازیشناخت آرایه ها و مفهوم آن مقایسه انواع روش های جستجو با هم
اسلاید 49: هدفهاي رفتاري از آرایه ها در حل مسئله استفاده کند . با استفاده از آرایه ها لیستی را مرتب نماید . در صورت لزوم در لیستی جستجو انجام دهد . دانشجو پس از مطالعه اين فصل بايد بتواند:
اسلاید 50: مقدمهفرض كنيد بخواهيم اطلاعات 100 كارمند را از ورودي بخوانيم و سپس آنها را مرتب كنيم، در اينصورت بايد وروديها را در جايي از حافظه ذخيره كنيم. در زبانهاي برنامهنويسي معمولا از آرايه براي ذخيره اطلاعات در حافظه استفاده ميكنند. در آرايهها ما با توجه به تعداد وروديها، طول آن را مشخص ميكنيم. سپس دادهها را خوانده در آن قرار ميدهيم.
اسلاید 51: تعريف آرايهخانههاي پشت سر هم از حافظه، كه همنوع بوده و توسط يك اسم معرفي ميشوند، آرايه نام دارد. نحوه دسترسي به هر يك از اعضاء آرايه، از طريق انديس آرايه امكانپذير است . براي تعريف آرايه ابتدا طول آرايه كه در حقيقت تعداد خانههاي آن را مشخص ميكند، معين ميكنيم. سپس نوع خانهها بايد معين شوند.در فلوچارتها آرايهها را بصورت زير نمايش ميدهيم:Name[ 1 .. Length ] طول آرايه اسم آرايه
اسلاید 52: براي خواندن يك آرايه از ورودي از حلقهها استفاده ميكنيم. فلوچارت خواندن آرايه از ورودي بصورت زير ميباشد:a[1..100]if i<=100 Noyes Read(a[i])i i+1i 1
اسلاید 53: با توجه به فلوچارت بالا براي دسترسي به عنصر iام آرايه در حالت كلي بصورت : Nam [ index ] انديس آرايه اسم آرايه عمل ميكنند.مثال: فلوچارتي رسم كنيد كه يك آرايه حداكثر 100 عنصري را از ورودي دريافت كرده، سپس آن را خروجي نمايش دهد.
اسلاید 54: a[1..100]i 1if i<=N Noyes Read(a[i])i i+1BeginRead(N)i 1if i<=N yes write(a[i])i i+1NoEnd
اسلاید 55: مثال : فلوچارتي رسم كنيد كه عددي را از ورودي دريافت كرده آن را به مبناي 2 ببرد.a[1..20]i 1if N>0 NoyesN N div 2Read(N)i i-1if i >0 yes write(a[i])i i-1NoEnd a[i] N mod 2i i+1
اسلاید 56: a[1..100]i 1k 3a[1] 2a[2] 1 Read(N)مثال : فلوچارتي رسم نمائيد كه عددي از ورودي دريافت كرده سپس اعداد اول قبل از آن را توليد نموده ، در يك آرايه قرار دهد.
اسلاید 57: Noif j<=i div 2 yesj j+1if i<=N j 2k 0i 1if i<k End write(a[i])i i+1if I mod j = 0 yesNoif k=0 a[k] ik k+1yesi i+1NoAyesk 1NoyesNoA
اسلاید 58: جستجو و مرتب سازي ( search and sort )يكي از مسائلي كه در بحث طراحي الگوريتم بسيار مهم است، بحث مرتبسازي و جستجو ميباشد. منظور از جستجو اينست كه يك مقداري را از يك ليست جستجو كنيم و منظور از مرتبسازي اينست كه يك ليست مرتب از دادهها را توليد كنيم.براي جستجو و مرتبسازي الگوريتمهاي مختلفي وجود دارد در زير الگوريتمهای اوليه، براي جستجو و مرتبسازي را بررسي ميكنيم.
اسلاید 59: الگوریتم های جستجو ( search)دو الگوريتم زير غالباً براي جستجو بكار ميروند:جستجوي خطي linear searchجستجوي دودوئی binary search
اسلاید 60: در جستجوي خطي عبارت مورد جستجو را به ترتيب با اولين، دومين و … عنصرآرايه مقايسه ميكنيم اگر عنصر مورد جستجو پيدا شد اندیس آن را نمايش ميدهيم. جستجوي خطي linear search
اسلاید 61: فلوچارت جستجوي خطي بصورت زير است:list[1..100]i 1index 0falg 0 Read(x)i 1if (i<=N) and (flag=0) Noif list[i]=x i i+1index iflag 1write(index)Endyesyes
اسلاید 62: جستجوي دودوئی binary searchدر جستجوي دودوئی ، ليست مورد جستجو، مرتب ميباشد. لذا براي جستجو اعمال زير انجام ميشود:1- عنصر X با عنصر وسط آرايه كه انديس آن برابر middle (low+high)/2 مقايسه ميشود.
اسلاید 63: 2ـ اگر x از عنصر وسط كوچكتر باشد، عنصر مورد نظر احتمالاً در قسمت بالای ليست قرار دارد. لذا آرايه با انديس، جديد در نظر گرفته ميشود و قسمت پايين ليست از فضاي جستجو حذف ميشود.3ـ اگر x از عنصر وسط آرايه بزرگتر باشد قسمت بالاي ليست حذف ميشود و فضاي جستجو، قسمت پايين آرايه خواهد بود.4- اگر x برابر عنصر وسط باشد عمل جستجو خاتمه ميپذيرد.
اسلاید 64: مرتبسازي بحث بعدي اين فصل ميباشد. براي مرتب كردن دادهها نيز الگوريتمهاي مختلفي وجود دارد، كه هر كدام مزايا و معايب خاص خود را دارد. بحث مفصل در اين مورد را به فصلهاي بعد واگذار ميكنيم.مرتب سازي (sort )
اسلاید 65: تمرين فلوچارتي رسم نمائيد كه عددي از ورودي دريافت كرده، اعداد كامل قبل از خود را توليد و در يك آرايه قرار دهد.فلوچارتي رسم نمائيد كه يك آرايه حداكثر 100 عنصري از ورودي دريافت كرده، عناصري از آن كه اول هستند را با صفر كردن حذف نمايد.فلوچارتي رسم نمائيد كه يك عدد حداكثر 20 رقمي را توسط آرايهاي از ورودي دريافت نمايد. سپس يك عدد تک رقمي را از ورودي خوانده در عدد 20 رقمي ضرب نموده، حاصل را در خروجي چاپ نمايد.
اسلاید 66: فصل 4 ساختار برنامه در زبان پاسکال هدفهاي كليشناخت ساختار يك برنامه در زبان پاسكال شناخت اجزاي تشكيل دهنده يك برنامه بررسي دستگاههاي خروجي و دستورات لازم در زبان پاسكال براي توليد خروجي
اسلاید 67: هدفهاي رفتاري اجزاء لازم براي نوشتن برنامه در زبان پاسكال را بداند. يك شناسه صحيح در زبان پاسكال را تعريف كند. ساختار يك برنامه در زبان پاسكال و اعلانهاي مربوط به برنامه را تعريف نمايد. يك برنامه ساده به زبان پاسكال كه فقط خاصيت خروجي دارد، بنويسد. دانشجو پس از مطالعه اين فصل بايد بتواند:
اسلاید 68: کلمات ذخيرهشده ( Reserved Words )شناسهها ( identifier ) اجزاي تشکيلدهنده يک برنامه
اسلاید 69: کلمات ذخيره شده، کلماتي هستند که مترجم زبان آنها را ميشناسد و معناي خاصي براي زبان دارند. مترجم زبان به محض مشاهده اين کلمات اعمال خاصي را انجام ميدهد. هر زبان داراي تعداد مشخصي کلمات ذخيره شده ميباشد و اين تعداد قابل افزايش توسط برنامهنويس نيست. کلمات ذخيرهشده ( Reserved Words )
اسلاید 70: ليست کلمات ذخيره شده در پاسکال عبارتند از: and exports mod shrasm file nil stringarray for not thenbegin function object tocase goto of typeconcat if or unitconstructor implementation packed untildestructor in procedure usesdiv inherited program vardo inline record withdownto interface repeat whileelse label set xorend library shl
اسلاید 71: شناسه در پاسکال براي نامگذاري ثابتها، تايپها، پروسيجروها، توابع، ميدانهاي يک رکورد، برنامه و همچنين يونيت مورد استفاده قرار ميگيرد. شناسهها ( identifier )
اسلاید 72: در حالت کلي دو نوع شناسه وجود دارد :id هاي استاندارد: اين نوع id ها از قبل در زبان پاسکال تعريف شدهاند و در برنامهها، معناي خاصي دارند . id هاي غيراستاندارد: اين نوع id ها بوسيله کاربر بطور مجزا تعريف ميشوند و اصطلاحاً به آنها userdefined گفته ميشود.
اسلاید 73: ساختار برنامه در زبان پاسکال اجزاء اصلي يک برنامه به زبان پاسکال بصورت زير ميباشد:عنوان برنامهقسمت تعاريف برنامه قسمت دستور العملها
اسلاید 74: قسمت تعاريف برنامهاعلان ثابتها Constant Declarationاعلان انواع Type Declarationاعلان متغيرها Declaration Variable اعلان برچسبها Declaration Label
اسلاید 75: درحالت کلي ميتوان شکل يک برنامه در زبان پاسکال را بصورت زير بيان کرد:استفاده از کلمه ذخيره شده Program و اسم برنامه ( که ميتواند بکار برده نشود ) قسمت تعاريف شناسهها بلوک اصلي برنامه که با Begin شروع و به End همراه نقطه ( . ) ختم ميشود.هر دستور در پاسکال به ( ; ) ختم ميشود.
اسلاید 76: نمودارهاي يک برنامه و بلوک بترتيب به صور ت زير ميباشد: Programشناسه)شناسه(;block0,BeginStatementEnd.;
اسلاید 77: مثال هاي حل شده Program Print ( output ) ;Begin Writeln ( Pascal Language ) ; Writeln ( Hello ) ;End.
اسلاید 78: خروجي برنامه بالا بصورت زير ميباشد: Pascal Language Hello
اسلاید 79: فصل 5انواع عملگرها و دادهها در زبان پاسکالهدفهاي كليشناخت انواع دادههامعرفي انواع عملگرها در زبان پاسكال بررسي اولويت عملگرهامعرفي دستورات جايگزيني در پاسكال
اسلاید 80: دانشجو پس از مطالعه اين فصل بايد بتواند: هدفهاي رفتاريانواع عملگرها در زبان پاسكال را بكار ببرد انواع دادهها براي يك برنامه را تعريف كند.اولويت عملگرها در يك عبارت را تشخيص دهد.يك برنامه ساده با عمليات معمولي را بنويسد.
اسلاید 81: عملگرها عملگرها نمادهايي هستند که براي انجام اعمال خاصي مورد استفاده قرار ميگيرند.عملگرها براي انجام اعمال خاصي روي عملوندها ( Operands ) بکار ميروند. با توجه به نوع عملگر ممکن است يک يا دو عملوند وجود داشته باشد. عملگرها در زبان پاسکال از تنوع زيادي برخوردارند.
اسلاید 82: در پاسکال چهار دسته عملگر وجود دارند :محاسباتي رابطه اي منطقي بيتي
اسلاید 83: عملگرهاي محاسباتي
اسلاید 84: عملگرهاي رابطه اي
اسلاید 85: عملگرهاي منطقي
اسلاید 86: عملگرهاي بيتي
اسلاید 87: تقدم عملگرها
اسلاید 88: انواع دادهها ( data types ) دادههاي ساده (Simple data type) دادههاي ساختيافته ( ( Structural Data Types دادههاي اشارهگر (Pointer Data Types)
اسلاید 89: دادههاي ساده (Simple data type)صحيح ( integer )اعشاري (حقيقي) نوع منطقي (Boolean type) نوع کاراکتري (Char type) نوع رشته اي (String type)
اسلاید 90: صحيح ( integer )
اسلاید 91: اعشاري (حقيقي)
اسلاید 92: دادههاي ساختيافته ( ( Structural Data Types انواع دادههاي ساختيافته عبارتند از:آرايههارکوردهامجموعههافايلها
اسلاید 93: متغيرها (Variables) متغير، محلي از حافظه است که داراي نوع و اسم ميباشد. نوع متغير همان نوع داده بوده و اسم متغير از قواعد اسمگذاري شناسه تبعيت ميکند.در پاسکال براي معرفي متغيرها بصورت زير عمل ميکنند:Var (کلمه ذخيره شده) نوع متغير: اسم متغير ;
اسلاید 94: ثابتها (Constants) يک ثابت نام شناسهاي است که در آغاز يک برنامه، يک مقدار در آن جاگزين ميشود. درست مانند متغيرها. ثابتها را ميتوان بعنوان خانههايي از حافظه در نظر بگيريم که مقدار دادهها در آنها ذخيره ميشود ولي مقدار ثابت مشخص ميباشد، طوري که نميتوان مقدار يک ثابت را در برنامه خود بوسيله يک دستور تغيير داد.: براي تعريف يک ثابت بصورت زيرعمل ميکنيم مقدار ثابت = اسم متغير Const
اسلاید 95: دستور جايگزيني براي قرار دادن يک مقدار يا مقدار يک متغير داخل يک متغير ديگر، از دستور جايگزيني استفاده ميکنند. شکل کلي يک دستور جايگزيني در پاسکال بصورت زير است: عبارت محاسباتي = : اسم شناسه عبارت قياسي يا عبارت منطقي
اسلاید 96: افزودن توضيحات به برنامه (Comment) افزودن مطلب توضيحي در درون خود برنامه عملي پسنديده و مطلوب است بدين ترتيب که بعد از مدتي امکان فراموشي کار با برنامه از بين ميرود و در کل ميتوان گفت که نوشتن توضيحات در برنامه خوانايي آن را بالا ميبرد. در پاسکال توضيحات بين دو آکولاد محصور ميشوند.{ This is comment } { This program written by A. Pascal }
اسلاید 97: مثال جابجا کردن مقدار دو متغير 151715 17151715171715aa ab bb temptempab
اسلاید 98: Program Example4 ; Var a , b , temp : integer Begin a : = 15 ; b : = 17 ; temp : = 0 ; temp : = a ; a : = b ; b : = temp ; Writeln ( a = , a , b = , b ) ; End . { End . of program } خروجي برنامه : a = 17 b = 15
اسلاید 99: چند نکته در مورد برنامهنويسي استفاده از اسامي با مفهوم براي متغيرها استفاده از دستور Const در صورتي که مقدار ثابت در برنامه وجود داشته باشد.سوال جوابي بودن برنامه (وروديها و خروجيها بايد داراي پيغام مناسب باشند)نوشتن برنامه با فرمت مناسب (رعايت قرار گرفتن خطوط مختلف برنامه زير هم و فاصله گذاشتن آنها از اول سطر و غيره)
اسلاید 100: تمرينات حاصل عبارتهاي زير را بدست آوريد:3 * 13 Mod 3 div 3 = ? 7.3 * 5 / 3 = ?( 3 + 4 < 6 ) and ( 4 + 7 < 13 ) = ?33 – 8 * 3 div 3 mod ( 5 div 3 ) = ?NOT ((( 3 – 4 MOD 3 ) < 5 ) and (( 6 div 4 ) < > 3 ))
اسلاید 101: : حاصل عبارتهاي منطقي را به ازاء مقادير زير مشخص کنيدA: = true ; B: = false ; C: = true ;( A AND B ) OR ( A AND C ) = ?( A OR NOT B ) and ( Not A OR C ) = ?A OR B AND C = ?D) NOT ( A OR B ) AND C = ?
اسلاید 102: تمرينات برنامهنويسي برنامهاي بنويسيد که ابعاد مثلث که عبارتند از 3 , 1.3 را در نظر گرفته محيط و مساحت آن را محاسبه و با پيغام مناسب در خروجي چاپ کند.برنامهاي بنويسيد که دو متغير صحيح با مقادير 3 , 15 را در نظر گرفته محتويات دو عدد را بدون استفاده از متغير کمکي جابجا نمايد.برنامهاي بنويسيد که سه عدد بنام هاي Third , Second , First بترتيب با مقادير 17 , 15 , 13 را در نظر گرفته بطور چرخشي مقادير آنها را جابجا نموده در خروجي با پيغام مناسب چاپ کند.
اسلاید 103: qفصل 6ورودي و خروجي هدفهاي كليمعرفي خروجي فرمتبندي شدهWriteln معرفي دستورات خروجي بررسي دستورات ورودي Read و ReadLn
اسلاید 104: هدفهاي رفتاريعبارات مورد نظر را در خروجي نمايش دهد.عبارات خروجي را با فرمت مناسب چاپ كند.متغيرهاي مورد نياز برنامه را از ورودي دريافت نمايد.برنامههاي ساده به زبان پاسكال بنويسد.دانشجو پس از مطالعه اين فصل بايد بتواند:
اسلاید 105: خروجي با دستور Write اين دستور براي نوشتن اطلاعات در خروجي بکار ميرود. اطلاعات خروجي ميتوانند ثابتهاي عددي، مقادير متغيرها، عبارات و غيره باشند. شکل دستور در حالت کلي بصورت زير است: (....... و متغير2 و متغير1 )write يا (....... و عبارت 2 وعبارت1 ) يا (....... و ثابت 2 وثابت 1 )
اسلاید 106: مثال Var A , B: integer ; Ch: char ; R: Real ;Begin A: = 10 ; B: = 15 ; Ch: = T ; R: = 12.25 Write ( A = , A, B = , B ) ; Write ( ch = , ch , R= , R ) ; Write ( sum of A and B = , A + B ) ; End. { end of program }بعد از اجراي برنامه فوق در خروجي خواهيم داشت: A = 10 B = 15 ch = TR = 1.2250000000 e + 01 sum of A and B = 25
اسلاید 107: خروجي با دستور Writeln اين دستور همانند دستور Write عمل ميکند با اين تفاوت که بعد از اجرا، کنترل را به ابتداي سطر بعد منتقل ميکند در نتيجه موجب چاپ دادههاي بعدي در ابتداي سطر بعد ميشود.
اسلاید 108: Var A , B: integer ; Ch: char ; R: Real ;Begin A: = 10 ; B: = 15 ; Ch: = T ; R: = 12.25 ; Writeln ; { new line } Writeln ( A = , A , B = , B ) ; Writeln ( Ch = , ch , R = , R ) ; Writeln ( Sum of A and B = , A + B ) ;End. { End of program } مثال خروجي برنامه بصورت زير ميباشد: A = 10 B = 15Ch = T R = 1.225000000 e + 01Sum of A and B = 25
اسلاید 109: خروجي فرمتبندي شده اگر بخواهيم اطلاعات با فاصله هاي مشخص يا در مکان مشخصي در صفحه نمايش قرار گيرند، بايد فرمت چاپ را در دستورات بيان شده مشخص کنيم.
اسلاید 110: طريقه تعيين فرمت چاپ براي اعداد صحيح فرمت اعداد صحيح بصورت زير مشخص ميشود: ( طول ميدان: داده صحيح ) Writeln يا Write
اسلاید 111: اگر طول ميدان از طول ارقام عدد صحيح بيشتر تعريف شود، عدد در منتهياليه سمت راست ميدان نوشته ميشود.اگر طول ميدان از طول ارقام عدد صحيح کمتر تعريف شود، طول ميدان به اندازه تعداد ارقام در نظر گرفته ميشود و طول ميدان تعريف شده بياثر خواهد بود.در تعريف طول ميدان براي متغيرها يا دادههايي از نوع صحيح به نکات زير توجه کنيد:
اسلاید 112: X:= 3200 ; A: = 12 ;B: = 217 ;Write ( X:3 , A:5 , B:5 ) ; مثال : خروجي 320012217
اسلاید 113: طول ميدان اعداد اعشاري براي نمايش اعداد اعشاري بصورت دلخواه، مي توان با تعريف طول ميدان و تعداد ارقام اعشاري، عدد مزبور را نمايش داد. : در حالت کلي طول ميدان را ميتوان به صورت زير تعريف کرد Write ( تعداد ارقام بعد از مميز: طول ميدان: متغير اعشاري ) يا Writeln
اسلاید 114: در تعريف فرمت براي اعداد اعشاري به نکات زير بايد توجه کرد: اگر طول ميدان بزرگتر از تعداد ارقام عدد ذکر شود، عدد در منتهي اليه سمت راست ميدان چاپ ميشود.اگر فقط طول ميدان ذکر شود، عدد به صورت نماد علمي در طول ميدان مشخص شده چاپ می شود .از آنجائي که براي نمايش اعداد در نماد علمي حداقل 8 محل مورد نياز است، لذا هنگامي که تنها طول ميدان ذکر شده باشد، اگر از 8 رقم کمتر باشد، حداقل 8 رقم در نظر گرفته ميشود.
اسلاید 115: هنگامي که طول ميدان همراه با تعداد ارقام بعد از مميز ذکر شود، اگر طول ميدان کوچکتر از مقدار عدد باشد، پاسکال تنها طول ميدان را به اندازهاي که مورد نياز است تصحيح کرده و آنرا برابر اندازه واقعي که عدد در آن قرار ميگيرد، اصلاح ميکند. اگر تعداد ارقام بعد از مميز زياد باشد و تعداد ارقام بعد از مميز ذکر شده در طول ميدان کمتر از تعداد ارقام اعشاري عدد باشد، تعداد ارقام اعشار مطابق درخواست برنامهنويس نشان داده خواهد شد و رقم آخر اعشار آن نسبت به عدد بعدي گرد ميشود.
اسلاید 116: طول ميدان کاراکترها و رشتهها براي نمايش رشتهها و کاراکترهاي با طول ميدان بصورت زير عمل ميکنيم. Write ( طول ميدان: متغير يا عبارت رشتهاي يا کاراکتري )در توربو پاسکال، کليه موارد گفته شده در مورد اعداد صحيح براي رشتهها نيز صادق است.
اسلاید 117: ورودي با Readln , Read از اين دستور براي خواندن داده ها و اختصاص آنها به متغيرها استفاده ميشود. در خواندن داده ها به دو موضوع بايد دقت شود: 1- منبع دادهها يعني دستگاه ورودي که از آن دادهها خوانده ميشود.. 2- متغيري که دادههاي خوانده شده در آن قرار ميگيرد
اسلاید 118: شکل کلي دستور ورودي Read بصورت زير ميباشد:;( ..... و متغير 2 و متغير 1Read ( اين دستور عمل خواندن دادهها و ذخيره آنها در متغيرها را انجام ميدهد و پس از اتمام عمل خواندن کنترل را براي خواندن و نوشتنهاي بعدي. در همان خط نگه ميدارد
اسلاید 119: program Example_1 ( input , output ) ;Var first , second , temp: integer ;Begin Writeln ; Writeln ( Please Enter two numbers ) ; Readln ( first , second ) ; Temp: = first ; First: = second ; Second: = temp ; Write ( first = , first , second = : 10 , second ) ;End. { end of program }مثال جابجا کردن محتويات دو عدد
اسلاید 120: خروجي برنامه بالا به صورت زير ميباشد:Please Enter two numbers 15 17First = 17 second = 15
اسلاید 121: تمرينات Value1: = 27.3 ;Value2: = -8.5 ;Writeln ( Value1 is , Value1 ) ;Writeln ( Value2 is , Value2 ) ;Sum: = Value1 + Value2 ;Writeln ( Sum of Two Values = , Sum: 6: 2 ) ;: خروجي قطعه برنامه زير را تعيين کنيد
اسلاید 122: اگر متغير X از نوع real و مقدار آن 12.235 و متغير 3 از نوع صحيح و مقدار آن 100 باشد خروجي دستورات زير را تعيين کنيد؟Writeln ( X is : 10 , X: 6: 2 , I is : 4 , I: 5 ) ;Writeln ( I is : 10 , I: 1 ) ;Writeln ( X is : 10 , X: 2: 1 ) ;Writeln ( X is : 15 , X: 7: 1 ) ;Writeln ( I is : 10 , X is : 10 , X: 7: 3 ) ;
اسلاید 123: تمرينات برنامه نويسيبرنامهاي بنويسيد که دو عدد را از ورودي دريافت کرده و محتويات آنها را بدون استفاده از متغير کمکي جابجا نمايد. برنامهاي بنويسيد که سه عدد صحيح Third , Second , first را از ورودي با پيغام مناسب دريافت کرده سپس محتويات اين سه متغير را بصورت چرخشي جابجا نموده با پيغام مناسب در خروجي چاپ کند.
اسلاید 124: برنامهاي براي يک حسابدار اداره جمع آوري ماليات بنويسيد که صورت حسابهاي ماليات را محاسبه نمايد.ورودي: شماره شناسايي ماليات دهنده بهاي ارزيابي شده نرخ ماليات خروجي: صورت حساب بافرمت مناسب شامل تمام دادههاي ورودي و ميزان بدهي
اسلاید 125: فصل 7ساختارهاي شرطي و كنترلي هدفهاي كليمعرفي دستور caseIf and Elseمعرفي دستور شرطي بررسي دستورات تكرار for ، while ، repeat untilمعرفي دستورات شرطي متداخلبررسي چند تابع و روال استاندارد زبان پاسکال
اسلاید 126: ÷ هدفهاي رفتاري برنامههايي را بنويسد كه در آنها نياز به استفاده از شرط وجود دارد. تفاوتهاي بين دستورات مختلف با if و else- if را تشخيص دهد. برنامههايي كه نياز به تكرار تعدادي عمليات داشته باشند را بنويسد. در صورت نياز بتواند در برنامهها، از روالها و توابع استاندارد زبان استفاده نمايد.دانشجو پس از مطالعه اين فصل بايد بتواند:
اسلاید 127: دستورات شرطي بطور کلي توسط اينگونه دستورات ميتوان بر حسب شرايط مختلف، تصميمات متفاوتي را اتخاذ نمود و برحسب برقرار بودن يا نبودن شرايط دستورات متفاوتي را اجرا نمود. دستورات شرطي در حالت کلي به دو نوع تقسيم ميشوند:if دستورCase دستور
اسلاید 128: دستور if هرگاه در طول برنامه نياز به استفاده از شرط يا شروط داشته باشيم، از دستور ستفاده ميکنيم. If دستور if بطور کلي به سه شکل بر حسب نياز ممکن است ظاهر شود: ساده ifElse همراه if هاي متداخل if
اسلاید 129: If – then در اين نوع دستور شرطي اگر شرط خاصي تحقق يافته باشد، عمل يا اعمال خاصي انجام ميشود. در غير اينصورت برنامه روال عادي خود را طي ميکند، در صورتي که شرط برقرار باشد ارزش منطقي Ture به خود ميگيرد و اگر شرط برقرار نباشد، ارزش منطقي False به خود خواهد گرفت.
اسلاید 130: If – then ( ادامه )ifشرط ياشروطدستورThenشناسه ;شکل کلي دستور if بصورت زير ميباشد: then شرط يا شروط if ; دستور دياگرام دستور بالا بصورت زير ميباشد:
اسلاید 131: Program Example ;Var Number: integer ; Begin Write ( Please enter Number: ) ; Readln ( Number ) ; if Number > 0 then Write ( Number is positive ) ; End . مثالخروجي برنامه بالا بصورت زير است: Please enter Number: 12Number is positive
اسلاید 132: در اين دستور ابتدا شرط بررسي ميشود، در صورتي که شرط برقرار باشد، عمل يا اعمال خاصي را انجام ميدهد و در صورتي که شرط برقرار نباشد، عمل يا اعمال بخصوص ديگري را انجام خواهد داد. اينگونه دستورات در واقع حالت توسعه يافته دستورات if ميباشند. دستور if همراه else
اسلاید 133: شکل کلي اين دستور بصورت زير است:if عبارت يا عبارات منطقي thenدستور1 ;else دستور2 ;ifعبارت يا عبارات منطقيthenدستورelse دستور;دياگرام دستور بصورت:
اسلاید 134: Program Example ;Var Number: integer ;Begin Writeln ( Please enter Number: ) ; Readln ( Number ) ; if ( Number mod 2 ) = 0 Then Write ( even ) else Write ( odd ) ;End. { end of program } مثالخروجي برنامه بالا بصورت زير است: Please enter Number: 17odd
اسلاید 135: If عبارت منطقيThen Begin دستور 1 ; دستور 2 ; . . .End Else Begin دستور 1 ; دستور 2 ; . . . End ; صورت ديگر دستور
اسلاید 136: If هاي متداخلهرگاه در نوشتن برنامه نياز به انتخاب يک شرط از بين چند شرط داشته باشيم، معمولاً از If متداخل استفاده ميکنند. در چنين مواقعي استفاده از If متداخل کارائي برنامه را بالا ميبرد زيرا بجاي کنترل تمام شروط فقط تا زمانيکه شرط برقرار نشده، If ها بررسي ميشوند. بعد از برقرار شدن يکي از شروط، کنترل برنامه به بعد از If منتقل ميشود و اين در بهبود کارائي يک برنامه ميتواند بسيار موثر باشد.
اسلاید 137: در حالت کلي If متداخل به صورت هاي زير ممکن است، در برنامه ظاهر شود.... elseدستور 3 ;دستور2then عبارت شرطي3 else Ifelseدستور2دستور 1then عبارت شرطي 2 else ifthen عبارت شرطي2 if دستور 1then عبارت شرطي 1 ifthen عبارت شرطي1 if ( 2
اسلاید 138: مثال : برنامهاي بنويسيد که نمره دانشجوئي را از ورودي دريافت کرده، با توجه به مقدار نمره يکي از خروجي هاي زير را نمايش دهد:Grade خروجي17 – 20 A 14 - 17 B12 – 14 C10 – 12 D0 – 10 F
اسلاید 139: Var Grade : Real ;Begin Write ( please enter a Real Number : ) ; Readln ( Grade ) ; if Grade > = 17.0 Then Writeln ( Grade is A ) Else If Grade > = 14.0 Then Writeln ( Grade is B ) Else If Grade > = 12.0 Then Writeln ( Grade is C ) Else If Grade > = 10 Writeln ( Grade is D ) Else Writeln ( Grade is F ‘(; Writeln ( Press any Key … : 30 ) ; Readln ;End . { end of program }
اسلاید 140: دستور Case زبان پاسکال دستورCase را بصورت زير در نظر ميگيرد: Of عبارت Case; دستور 1 : مقدار 1; دستور 2 : مقدار 2 ; دستور 3 : مقدار3 . . . Otherwise ; دستورEnd ; { End of case }
اسلاید 141: مثال : برنامهاي بنويسيد که دو عدد به همراه يک عملگر را از ورودي دريافت کرده، کار يک ماشين حساب ساده را شبيهسازي نمايد.Var a , b: Real ; op: char ;Begin Write ( please enter two Numbers: ) ; Readln ( a , b ) ; Write ( please Enter A operator: ) Readeln ( op ) ; Case op of + : Writeln ( Sum = , ( a + b ): 6: 2 ) ; - : Writeln ( Subtract = , ( a - b ): 6: 2 ) ; * : Writeln ( Multiple = , ( a * b ): 6: 2 ) / : Writeln ( divide = , ( a / b ): 6: 2 ) ; End; { End of Case }End. { end of program }
اسلاید 142: دياگرام دستور Case بصورت زير ميباشد: CaseعبارتثابتofدستوراتEnd;:,
اسلاید 143: ساختارهاي کنترلي بسياري از مواقع لازم است عمل يا اعمال به تعداد دفعات معين يا نامعين انجام شوند. در چنين مواقعي زبانهاي برنامهنويسي دستوراتي دارند که ميتوان اين اعمال تکراري را انجام داد. در حالت کلي ساختارهاي کنترلي شامل يک يا چند شرط و همچنين متغير يا اصطلاحاً شمارندهاي براي پايان دادن به شرط ميباشند
اسلاید 144: شکل کلي حلقه بصورت زير ميباشد: Do مقدار نهايي To مقدار اوليه =: انديس For ; دستوربايد توجه داشته باشيد که در حلقه تعداد تکرار کاملاً مشخص است و حلقه دقيقاً به تعداد تکرار مشخص اجرا ميشود.
اسلاید 145: حلقه for اين دستور براي انجام عمل يا اعمالي مشخص به تعداد تکرار معين بکار برده ميشود. حلقه for شامل يک انديس ( index ) مقدار اوليه ( initial value ) مقدار نهايي ( final value ) و مقدار افزاينده ميباشد. اين حلقه با قرار دادن مقدار اوليه در انديس حلقه شروع شده و بعد از هر تکرار يک واحد به انديس حلقه اضافه ميکند تا در نهايت به مقدار نهايي برسد. شکل کلي حلقه بصورت زير ميباشد:
اسلاید 146: Var i , number , Sum: integer ;Begin Writeln ( please enter 100 Numbers: ) ; For I: = 1 to 100 do Begin Readln ( number ) ; Sum:= Sum + number ; End ; Writeln ( Sum = , Sum ) ; End. { end of program } مثال : برنامهاي بنويسيد که 100 عدد از ورودي دريافت کرده، مجموع 100 عدد را محاسبه و چاپ نمايد.
اسلاید 147: دستور for را بصورت زير هم ميتوان بکار برد.do مقدار نهايي downto مقدار اوليه = : انديس for ; دستوردر اين شکل از دستور For ابتدا مقدار اوليه در انديس حلقه قرار داده مي شود و بعد از آن در هر تکرار حلقه يک واحد از انديس حلقه کم مي شود تا به مقدار نهايي برسد .
اسلاید 148: مثال : برنامهاي بنويسيد که عدد صحيحي را از ورودي دريافت کرده و فاکتوريل آن را محاسبه نمايد.Var i , n , Fact : integer ;Begin Fact : = 1 ; Write ( please enter A Number ) ; Readln ( n ) ; For I : = n downto 1 do Fact : = Fact * i ; Writeln ( Fact = , Fact ) ; End .
اسلاید 149: do مقدار نهايي to مقدار اوليه = : انديس1 for do مقدار نهايي to مقدار اوليه = : انديس for 2 ; دستور هاي متداخل For
اسلاید 150: For i: = 1 to 3 do Begin For j: = 1 to 3 do Write ( pascal : 8 ) ; Writeln ; End ; مثال :خروجي Pascal Pascal Pascal مرحله اول ( i = 1 ) Pascal Pascal Pascal مرحله دوم ( i = 2 ) Pascal Pascal Pascal مرحله سوم ( i = 3 )
اسلاید 151: دياگرام دستور for Forانديسdoمقدار اوليه:=مقدار نهاييDowntoدستورTo
اسلاید 152: حلقه While در حالت کلي هدف از بکار بردن اين دستور انجام عملياتي مشخص به تعداد دفعات نامعين است :اين حلقه به صورت زير بکار برده مي شود Do عبارت منطقي While ; دستور
اسلاید 153: Var m , n , r: integer ;Begin Writeln ( Please Enter Two Numbers ) ; Readln ( m, n ) ; While ( m Mod n ) < > 0 Do Begin r: = m MOD n ; m: = n ; n: = r ; End ; { end of while } Writeln ( B. M. M = , n ) ; End. { end of program }مثال : بزرگترين مقسوم عليه دو عدد
اسلاید 154: دياگرام دستور While بصورت زير مي باشد:Whileعبارت شرطيdoدستورBeginدستورEnd;و در صورتي که دستور مرکب باشد دياگرام بصورت زیر است :
اسلاید 155: دستور Repeat اين دستور نيز از نوع دستورات تکراري ميباشد و به کمک آن ميتوان يک يا چند دستور را به تعداد نامعين بار اجرا کرد. while اين دستور مشابه دستوراست، با تفاوتهايي که در زير عنوان ميکنيم:While برعکس دستور Repeat 1) در دستورشرط حلقه در انتهاي حلقه بررسي ميشود لذا حلقه حداقل يکبار اجرا ميشود.
اسلاید 156: 2) دستور Repeate تا زماني اجرا ميشود که شرط خاصي تحقق پيدا نکرده است در حاليکه دستور While تا زماني که شرط برقرار باشد، اجرا ميشود.3) دستور Repeat نياز به بلوک ندارد و همراه Until ظاهر ميشود.
اسلاید 157: شکل کلي اين دستور بصورت زير ميباشد: Repeat ; دستور1; دستور2 ..; شرط يا شروط until
اسلاید 158: Var i , Sum , Number : integer ; ave: Real ;Begin Writeln ( please enter Numbers While is Not Negative ) ; Sum: = 0 ; Ave: = 0 ; Repeat Readln ( Number ) ; Sum: = sum + Number ; i: = i + 1 ; Until number = 0 ; { End of Repeat } i: = i - 1 ave: = Sum / i ; Writeln ( Sum = , Sum , average = : 12 , ave: 7: 2 ) ;end.{ end of program }برنامه مجموع و ميانگين تعدادي عدد صحيح مثبت
اسلاید 159: دياگرام دستور Repeat بصورت زير ميباشد: Repeatدستور;Untilشرط يا شروط
اسلاید 160: معرفي چند پروسيجر ( Procedure ) پروسيجرها يا زير روالها قسمتهاي مستقلي از برنامه اصلي ميباشند که به تنهايي اعمال خاصي را انجام داده و وظايف مستقل و بخصوصي بر عهده آنها گذاشته ميشود. يک مزيت بزرگ پروسيجرها اينست که يکبار در برنامه گنجانده شده ولي در محلهاي مختلف ازآن استفاده به عمل ميآيد و از اصول برنامهنويسي ساخت يافتهاست.
اسلاید 161: پروسيجر Exit هدف: انتقال کنترل برنامه به خارج از بلوک فعليProcedure Exit ; استفاده از اين پروسيجر در هر بلوک از برنامه باعث ميشود که کنترل برنامه بلافاصله به خارج از آن بلوک انتقال يابد.
اسلاید 162: پروسيجر Break هدف: خاتمه دادن به اجراي يک حلقه Procedure Break ; استفاده از پروسيجر فوق باعث ميشود که اجراي يک حلقه خاتمه يافته و کنترل برنامه به دستورالعمل بعدي انتقال يابد.
اسلاید 163: پروسيجر continue هدف: بازگشت به ابتداي حلقه Procedure continue ; وقتي اين پروسيجر در حلقه ظاهر ميشود کنترل برنامه به اول حلقه انتقال مييابد و دستورات بعد از پروسيجر اجرا نميشوند.
اسلاید 164: ارائه چند مثال از کاربرد حلقه ها و شرطها مثال : برنامهاي بنويسيد که يک عدد صحيح در مبناي ده را از ورودي دريافت کرده، به يک عدد در مبناي 2 ببرد.
اسلاید 165: Var Number , N , Power , R: integer ; Begin Power: = 1 ; N: = 0 ; Write ( enter A Number: ) ; Readln ( Number ) ; Repeat R: = Number MOD 2 ; Number: = Number DIV 2 ; N: = N + Power * R ; Power: = Power * 10 ; Until Number < 2 ; N: = N + Number * Power ; Writeln ( Number In Base 2 = , N ) ; End. { end of program }
اسلاید 166: Var F1 , F2 , F3 , N: integer ; Begin Write ( please enter A Number: ) ; Readln ( N ) ; F1: = 0 ; F2: = 1 ; Write ( F1: 5 , F2: 5 ) ; For i: = 3 to N do Begin F3: = F1 + F2; If ( i mod 10 ) = 0 Then Writeln ; Write ( F3: 5 ) ; F1: = F2 ; F2: = F3 ; End ; { end of for }End. { end of program }مثال : برنامهاي بنويسيد که n عدد را از ورودي دريافت کرده، n جمله سري زير که به سري فيبوناچي معروف است را چاپ نمايد.
اسلاید 167: تمرينات a) Sum : = 0 ; While i < = 120 do Begin Sum : = Sum + i ; i : = i + 1 ; end ; b) i : = 0 ; Sum : = 0 ; While i < = 20 do Begin i : = i + 1 ; Sum : = Sum + i ; end ; 1- خروجي قطعه برنامههاي زير را تعيين کنيد:
اسلاید 168: c) b : = 5 ; Repeat Writeln ( b , ( b div 5 ) : 3 ) ; b : = b – 1 ; Until ( b div 3 ) = 5 ; d) Count : = 0 ; Stop : = 4 ; While Count < Stop Do Begin For K : = 1 to Count Do Write ( K : 3 ) ; Writeln ; Count : = Count + 1 ; End ;
اسلاید 169: تمرينات برنامه نویسی 1- برنامهاي بنويسيد که با استفاده از حلقه ها خروجي زير را توليد کند. 1 1 2 1 1 2 3 2 1 1 2 3 4 3 2 1 1 2 3 4 5 4 3 2 1
اسلاید 170: 2- برنامهاي بنويسيد که تعدادي عدد از ورودي دريافت کرده مجموع ارقام هر عدد را در خروجي چاپ نمايد. ( پايان داده ها به 1- ختم مي شود ) 3- برنامهاي بنويسيد که دو عدد صحيح را از ورودي دريافت کرده سپس:اعداد فيبوناچي بين اين دو عدد را چاپ کند.4- برنامهاي بنويسيد که يک اسکناس 1000 توماني را به حالتهاي مختلف يعني به اسکناس 200 توماني، 100 توماني، 50 توماني، 20 توماني، 10 توماني و سکه هاي 5 توماني و 2 توماني و يک توماني خرد نمايد.
اسلاید 171: فصل 8Arrayآرایه ها هدفهاي كليشناخت انواع آرايهها و موارد استفاده از آنهاشناخت لزوم استفاده از ساختار داده اي به نام آرايه شناخت مفاهيم مرتبسازي و جستجوشناخت الگوريتمهاي مرتبسازي و جستجو
اسلاید 172: ÷ هدفهاي رفتاري آرايهها يك بعدي را در برنامههاي خود بكار ببرد. ماتريسها را پيادهسازي نمايد. عمل جستجو در آرايه انجام دهد.يك ليست را توسط روشهاي مرتب سازي حبابی، انتخابي و غيره مرتب كند.دانشجو پس از مطالعه اين فصل بايد بتواند:
اسلاید 173: آرايه و انواع آن خانههاي پشت سرهم از حافظه که همنوع بوده و توسط يک اسم معرفي ميشوند، آرايه نام دارد. نحوه دسترسي به هر يک از اعضاء آرايه از طريق انديس آرايه امکانپذير است.براي تعريف آرايه ابتدا طول آرايه که درحقيقت تعداد خانههاي آنرا مشخص ميکند، معين ميگردد. سپس نوع خانههايي که دادهها در آن قرار خواهند گرفت را تعيين مي کنند
اسلاید 174: آرايههاي يک بعدي آرايههاي يک بعدي بصورت زير تعريف ميشوند: Name : array [ 1 . . Length ] of type ; نوع آرايه کلمه ذخيره شده طول آرايه کلمه ذخيره شده اسم آرايه
اسلاید 175: برای مثال : Var No: Array [ 1.. 50 ] of integer ; id: Array [ 1.. 20 ] of Byte ; Name , Fam: Array [ 1.. 30 ] of char ;
اسلاید 176: مقداردهي آرايهها مثل متغيرها به دو صورت امکانپذير است :1- با استفاده از دستورات ورودي2- مقداردهي در طول برنامهطريقه دسترسي به عناصر آرايه بصورت زير ميباشد: Name [ index ] انديس آرايه اسم آرايه
اسلاید 177: مثال : برنامهاي بنويسيد که 100 عدد صحيح از ورودي دريافت کرده، بيشترين مقدار و محل وقوع آن را در خروجي چاپ نمايد. Var No: array [ 1.. 100 ] of integer ;Max , i , index: integer ;Begin Writeln ( please enter TEN Numbers ) ; For i: = 1 to 100 do Readln ( No [ i ] ) ; Max: = No [ 1 ] ; Index: = 1 ; For i: = 2 to 100 do If No [ i ] > Max Then Begin Max: = No [ i ] ; Index: = i ; End ; Writeln ( The Maximum is = , Max ) ; Writeln ( And Index = , Index ) ;End. { End of program }
اسلاید 178: مثال: برنامهاي بنويسيد که يک آرايه 100 عنصري را از ورودي دريافت کرده عناصر آرايه را معکوس نمايد. Var i , temp : integer ; a : array [1 .. 100 ] of integer ;Begin Writeln ( please enter 100 Numbers : ) ; For i : = 1 to 100 do Begin Read ( a [ i ] ) ; If ( i Mod 10 ) = 0 Then Writeln ; End ; For i : = 1 to 50 do Begin Temp : = a [ 101 – i ] ; a [ 101 – i ] : = a [ i ] ; a [ i ] : = temp ; End ; End .
اسلاید 179: آرايههاي دو بعدي براي نمايش ماتريس درحافظه معمولاً از آرايههايي بنام آرايههاي دوبعدي استفاده ميکنند براي درک بيشتر اين آرايهها آنها را بصورت ماتريس در نظر ميگيرند. آرايههاي دو بعدي بصورت زير معرفي ميشوند: Name : array [ 1 .. row , 1 .. column ] of type ; نوع عناصر آرايه کلمه ذخيره شده تعداد ستونها تعداد سطرها کلمه ذخيره شده اسم آرايه
اسلاید 180: مثال : برنامهاي بنويسيد که يک ماتريس 5*5 را از ورودي دريافت کرده، سپس آنرا در خروجي چاپ نمايد. Var a : array [ 1 .. 5 , 1 .. 5 ] of integer ; i , j : integer ; Begin For i : = 1 to 5 do Begin For j : = 1 to 5 do Read ( a [ i , j ] ) ; Writeln ; End ; Writeln ; For i : = 1 to 5 do Begin For j : = 1 to 5 do Write ( a [ i , j ] : 5 ) ; Writeln ; End ;End.
اسلاید 181: آرايههاي چند بعدي ميتوان آرايههايي با ابعاد بيشتر از دو نيز تعريف کرد. بطور کلي براي معرفي يک آرايه چند بعدي مي توان بصورت زيرعمل کرد :Name : array [ 1.. length1 ] of array [ 1.. length2 ] …. Of array [ 1.. lengthN ] of Type و ياName: array [ 1.. length1 , 1.. length2 , …. 1.. lengthN ] of Type
اسلاید 182: نکاتي چند در مورد آرايهها تعريف آرايه با محدوده منفي براي مثال: A: array [ -10.. 10 ] of Real ; تعريف آرايه از نوع منطقي ( Boolean ) براي مثال: A: array [1.. 20 ] of Boolean ;
اسلاید 183: آرايههاي با محدوده منطقي: براي مثال A: array [ Boolean ] of integer;آرايهاي با محدوده کاراکتري: براي مثال A: array [ A.. Z ] of Real ;آرايهاي که براي اعضاي آن محدوديت قائل شويم براي مثال: A: array [ 1.. 20 ] of 1.. 30
اسلاید 184: جستجو و مرتبسازي ( Search and Sort ) يکي از مسائلي که در بحث طراحي الگوريتم بسيار مهم است، بحث مرتبسازي و جستجو مي باشد. منظور از جستجو اينست که يک مقداري را از يک ليست جستجو کنيم و منظور از مرتب سازي اينست که يک ليست مرتب از داده ها را ايجاد کنيم. حال تعدادی الگوريتم که براي مرتبسازي و جستجو بکار ميروند. را بررسي ميکنيم بخصوص زمانيکه ساختار داده ما يک آرايه باشد
اسلاید 185: جستجو در آرايه در کل دو نوع عمل جستجو را در اين کتاب بررسي ميکنيم :جستجوي خطي Linear search جستجو دودويي Binary search
اسلاید 186: جستجوي خطي Linear search در جستجوي خطي عبارت مورد جستجو را نخست با اولين عضو آرايه مقايسه ميکنيم، اگر برابر بود عمل جستجو با موفقيت همراه بوده و عمل جستجو خاتمه مييابد در غير اينصورت روند را ادامه داده و عبارت مورد جستجو را بترتيب با عضو دوم، سوم ... مقايسه ميکنيم تا اينکه حالت تساوي حاصل شود و اگر اين حالت حاصل نشد، عباريت مورد جستجو در ليست قرار ندارد.
اسلاید 187: قطعه برنامه زير را مي توان در حالت کلي براي جستجوي خطي بکار برد:Flag: = True ;i: = 0 ;While ( i < = N ) and ( flag ) Do Begin i: = i + 1 ; if A [ i ] = x Then Begin Index: = i ; Flag: = false ; End ; End ;If flag Then Writeln ( The Element is found )Else Writeln ( The Element is not found ) ;
اسلاید 188: جستجو دودويي Binary search درجستجوي دودوئي ليست اوليه بايدمرتب باشد. براي جستجو در چنين آرايهاي نخست انديس وسط آرايه را پيدا ميکنيم و عنصر واقع در اين انديس را با عبارت مورد جستجو مقايسه ميکنيم و حالات زير ممکن است حاصل شود:(Low انديس ابتداي آرايه و upper انديس آخرين عناصرآرايه و middle انديس عنصر وسط ميباشد.)
اسلاید 189: if A [ middle ] < X Then حالت اول : در اينصورت Low : = middle و مقدار جديد middle را که عبارتست از:Middle : = ( low + middle ) / 2
اسلاید 190: if A [ middle ] < X Then حالت دوم : در اينصورت upper : = middle و مقدار جديد middle را که عبارتست از:Middle : = ( low + middle ) / 2
اسلاید 191: if A [ middle ] = X Then حالت سوم : در اينصورت Write ( The Eiement is found ) Low < upper در صورتي که حالتهاي الف يا ب اتفاق بيفتد، عمل جستجو را تا زمانيکهمي باشد ادامه ميدهيم و در هر مرحله که حالت سوم رخ دهد عمل جستجو خاتمه مييابد.
اسلاید 192: مرتبسازي براي مرتبسازي دادهها روشهاي متفاوتي وجود دارد . تفاوت روشهاي مرتبسازي در زمان اجراي آنها مي باشد. در حالت کلي با توجه به تعداد وروديها (داده ها) و نوع مسئله مرتبسازي مي توان از انواع روشهاي مرتبسازي استفاده نمود.حال بعضي از روش هاي مرتب سازي عمومي را بررسي ميکنيم. مرتبسازي حبابي ( Bubble sort ) مرتبسازي انتخابي ( Selection sort )
اسلاید 193: مرتبسازي حبابي ( Bubble sort ) سادهترين روش مرتبسازي روش مرتبسازي حبابي ميباشد. يکي از خصوصيات بارز اين نوع مرتبسازي اين است که فهم آن ساده بوده و برنامهنويسي آن به سهولت انجام مي گيرد.مرتبسازي حبابي نخست عنصر اول و دوم را با هم مقايسه ميکند و در صورت نياز، آنها را جابجا ميکند، سپس عنصر دوم و سوم را مقايسه ميکند. اين عمل را تا زمانيکه به انتهاي آرايه نرسيده تکرار ميکند، در پايان مرحله اول بزرگترين عنصر در آخرين خانه آرايه قرار ميگيرد. در مرحله دوم از خانه اول تا خانه N – 1 عمل بالا را انجام ميدهد. اين روند را تا زمانيکه تمام عناصر آرايه مرتب نشدهاند ادامه ميدهد و در نهايت يک ليست مرتب شده بصورت صعودي در خروجي توليد ميشود.
اسلاید 194: For i: = 1 to n do For j: = 1 to n - 1 do If x [ j ] > x [ j + 1 ] Then Begin Temp: = x [ j ] ; X [ j ]: = x [ j + 1 ] ; X [ j + 1 ]: = temp ; End ; تعداد مقايسهها در اين روش بصورت زير محاسبه ميشود: n – 1 + n – 2 + … + 1 = N(N-1)/2
اسلاید 195: مرتبسازي انتخابي ( Selection sort )در اين روش مرتبسازي نخست کوچکترين عنصر را در کل آرايه پيدا کرده در خانه اول آرايه قرار ميدهيم سپس عنصر کوچکتر بعدي را يافته در خانه دوم قرار ميدهيم اين روند را تا زمانيکه کل آرايه مرتب نشده ادامه ميدهيم
اسلاید 196: For i: = 1 to n doBegin Min: = x [ i ] ; Index: = i ; For j: = i +1 to n do If x [ j ] < Min Then Begin Min: = x [ j ] ; Index: = j ; End ; { find The smallest Element } X [ index ]: = x [ i ] ; X [ i ]: = Min ; { swap Minimum With other Element }End ; { end of selection sort }قطعه برنامهاي که براي مرتبسازي انتخابي ميتوان نوشت بصورت زير ميباشد:
اسلاید 197: چند مثال در مورد آرايهها مثال : برنامهاي بنويسيد که يک عدد صحيح از ورودي دريافت کرده سپس اعداد اول قبل از آن را توليد و در آرايه قرار دهد.Var a : array [ 1 .. 50 ] of integer ; i , j , N : integer ; k : Byte ; flag : Boolean ;Begin Write ( Enter A Number : ) ; Readln ( N ) ; a [1] : = 2 ; a [2] : = 3 ; flag : = True ; k : = 2 ;
اسلاید 198: For i : = 4 to N do Begin For j : = 2 to ( i div 2 ) do If ( i mod j ) = 0 Then Flag : = false ; If flag Then Begin K : = k + 1 ; A [ k ] : = i ; End ; Flag : = Ture ; End ; { end of for } Writeln ( The prime Numbers before N ) ; For j : = 1 to K do Writeln ( a [ i ] : 5 ) ;End . { End of program }
اسلاید 199: مثال : برنامهاي بنويسيد که يک ماتريس 3*3 را از ورودي دريافت کرده و مجموع هر سطر را انتهاي همان سطر به همراه خود ماتريس در خروجي چاپ نمايد.Var a: array [ 1.. 3 , 1.. 3 ] of Real ; sum: Real ; i , j: byte ;Begin Writeln ( Enter Array ) ; for i: = 1 to 3 do for j: = 1 to 3 do Read ( a [ i , j ] ) ; Writeln ; Writeln ( The result matrix ) ; For i: = 1 to 3 do Begin For j: = 1 to 3 do Begin Write ( a [ i , j ]: 8: 2 ) ; Sum: = sum + a [ i , j ];{ calculate sum of any row } End ; Writeln ( sum: 8: 2 ) ; Sum : = 0 ; End ;End. { End of program }
اسلاید 200: مثال : برنامهاي بنويسيد که از ادغام دو آرايه مرتب ،آرايه سومي بنام L3 ايجاد کند بطوريکه آرايه سوم مرتب باشد.Var L1 , L2: array [ 1.. 30 ] of integer ; L3: array [ 1.. 60 ] of integer ; M , N , i , j , k: Byte ;Begin Write ( Enter Dimention of arrays: ) ; Readln ( N , M ) ; Writeln ( Enter first Array ) ; for i: = 1 to N do Read ( L1 [ i ] ) ; Writeln ( Enter second Array ) ; for j: = 1 to M do Read ( L2 [ i ] ) ;
اسلاید 201: i: = 1 ; j: = 1 ; k: = 1 ; while ( i < = N ) and ( j < = M ) Do Begin If L1 [ i ] > L2 [ j ] Then Begin L3 [ k ]: = L2 [ j ] ; J: = j + 1 ; End Else if L1 [ i ] < L2 [j ] Then Begin L3 [ k ]: = L1 [ i ] ; i: = i + 1 ; End Else Begin L3 [ k ]: = L1 [ i ] ; k: = k + 1 ; L3 [ k ]: = L2 [ j ] ; i: = i + 1 ; j: = j + 1 ; end ; k: = k + 1 ; End ; { end of while }
اسلاید 202: if i < = N Then for p: = i to n do Begin L3 [ k ]: = L1 [ p ] ; k: = k + 1 ; end Else if j < = M Then for p: = j to M do Begin L3 [ k ]: = L2 [ p ] ; k: = k + 1 ; end ; Writeln ; Writeln ( The result of merge is ) ; for i: = 1 to k - 1 do Begin Write ( L3 [ i ] : 5 ) ; If ( i mod 10 ) = 0 Then Writeln ; End ; { end of merge }End. { End of program }
اسلاید 203: مثال : برنامه ای بنويسيد که يک جمله حداکثر 80 کاراکتري را از ورودي دريافت کرده وسپس کاراکترهاي فضاي خالي را با کاراکترستاره جايگزين کند. Var state: array [ 1.. 80 ] of char ; i , N : integer ;Begin Writeln ( Enter Number of sentence: ) ; Readln ( N ) ; Writeln ( Enter sentence ) ; for i: = 1 to N do Read ( state [ i ] ) ; for i: = 1 to N do if state [ i ] = ‘ Then state [ i ]: = * ; Writeln ; Writeln ( The output sentence ) ; for i: = 1 to N do Write ( state [ i ] ) ; End. { End of program }
اسلاید 204: تمرينات - کداميک از دستورات زير در مورد اعلان زير صحيح است: الف- a [ A ]: = Z ب- a [ a ]: = A ج- a [ A ]: = 1 د- a [ I ]: = 12 ح- a [ i ]: = 12 a: array [ A .. Z ] of char
اسلاید 205: a: array [ -20.. 10 ] of char a: array [ -20.. -20 , 0.. -20 ] of A .. Z a: array [ Booleam ] of char a: array [ 1.. 10 , A .. Z ] of integer - تعداد بايتهايي که هر کدام از اعلانهاي زير اشغال مي کنند را محاسبه نمائيد.
اسلاید 206: تمرينات برنامهنويسی برنامهاي بنويسيد که که يک آرايه حداکثر 50 عنصري را از ورودي دريافت کرده و سپس عناصري از آرايه که اول هستند را با صفر جايگزين کرده آرايه حاصل را در خروجي چاپ کند.برنامهاي بنويسيد که عددي از ورودي دريافت کرده سپس آن را به عامل هاي اول تجزيه نمايد و حاصل را بصورت زير در خروجي چاپ نمايد:براي مثال: 21 = ( 3 ^ 1 ) * ( 7 ^ 1 )
اسلاید 207: برنامهاي بنويسيد که يک عدد از ورودي دريافت کرده سپس در صورت وجود صفرهاي آن را حذف نموده، نتيجه را در خروجي چاپ نمايد.برنامه اي بنويسد که يک ماتريس 5 * 5 را از ورودي دريافت کرده سپس مجموع هر سطر را انتهاي همان سطر و مجموع هر ستون را در انتهاي همان ستون چاپ نمايد.
اسلاید 208: برنامهاي بنويسيد که يک ماتريس حداکثر 10 * 10 را از ورودي دريافت کرده ماتريس هم بر حسب ستون و هم بر حسب سطر مرتب نموده به همراه ماتريس اوليه در يک سطر چاپ نمايد.برنامهاي بنويسيد که يک آرايه 200 عنصري ازنوع صحيح که 150 عنصرمرتب درآن قرار ميگيرد را از ورودي دريافت کرده سپس آرايه دومي با 50 عنصر را از ورودي بخواند.
اسلاید 209: فصل 9هاي كتابخانه ای توابع و روالهدفهاي كليشناخت توابع و روالهاي استاندارد براي نوعهاي صحيحشناخت ساختار تابع و روال شناخت توابع و روالهاي استاندارد براي نوعهاي اعشاري و كاركتريشناخت توابع و روالهاي استاندارد رياضي
اسلاید 210: ÷ هدفهاي رفتاري توابع و روالهاي استاندارد را در صورت نياز در برنامه استفاده كند. ساختار توابع و خروجيهاي آنها را تشخيص داده و در برنامه خود از آنها استفاده كند. ساختار روالها و خروجيهاي آنها را تشخيص داده و نتايج حاصل از آنها را مورد استفاده قرار دهد.توابع رياضي را براي محاسبه عبارت رياضي در برنامه بكار ببرد.دانشجو پس از مطالعه اين فصل بايد بتواند:
اسلاید 211: ساختار تابع در کل هدف تابع اينست که متغير يا متغيرهايي را بعنوان پارامتر از برنامه اصلي دريافت کرد. عمل خاصي را روي پارامترها انجام داده و نتيجه را به برنامه اصلي برگرداند. شکل کلي فراخواني توابع در برنامه اصلي بصورت زير ميباشد:ساختار تابع: Function Name ( parameters ) : Type نوع تابع پارامترها اسم تابع کلمه ذخيره شده
اسلاید 212: توابعي براي اعداد صحيح و اعشاري تابع Abs هدف: باز گرداندن قدر مطلق ( absolute ) پارامتري که به آن ارسال ميشود: Function Abs ( x: Integer ): Integer ; Function Abs ( x: Real ): Real ; اين تابع يک عبارت از نوع حقيقي يا صحيح را بعنوان آراگون دريافت کرده سپس قدر مطلق آن را محاسبه و حاصل را برگرداند.
اسلاید 213: مثال : Var f : Real ; I : Integer ; Begin F : = Abs ( - 191.15 ) ; I : = Abs ( - 171 ) ; Writeln ( f = , f : 8 : 2 , I = , I ) ; End . : خروجي حاصل F = 191.15 I = 171
اسلاید 214: تابع Sin هدف: باز گرداندن سينوس يک عدد از نوع اعشاري شکل تابع: Function Sin ( X: Real ): Real ; X يک عبارت يا عدد از نوع اعشاري بوده و حاصل مقدار سينوس X ميباشد.
اسلاید 215: مثال : Var X : Real ; Begin X : = sin ( 10 ) ; Write ( sin ( 10 ) = , x :8 : 2 ) ;End.
اسلاید 216: تابع Cos هدف: باز گرداندن کسينوس يک عدد از نوع اعشاري.شکل تابع: Function cos ( X: Real ): Real ; X يک عبارت با عدد از نوع اعشاري بوده و حاصل مقدار کسينوس X ميباشد.
اسلاید 217: Var X : Real ; Begin X : = cos ( 10 ) ; Write ( cos ( 10 ) = , x : 8 : 2 ) ;End . مثال :
اسلاید 218: تابع ArcTanهدف: بازگرداندن آرک تانژانت يک عدد از نوع اعشاريشکل تابع: Function ArcTan ( X: Real ): Real ; X يک عبارت يا عدد از نوع اعشاري بوده حاصل مقدار آرک تانژانت X ميباشد.
اسلاید 219: Var X : Real ; Begin X : = ArcTan ( 10 ) ; Write ( ArcTan ( 10 ) = , x : 8 : 2 ) ;End . توجه: در صورتي که در توابع مثلثاتي زاویه از نوع درجه ارائه شود ميتوان با فرمول زير معادل راديان آن را محاسبه کرد: Real = Dey * 3.14159 / 180
اسلاید 220: تابع Exp هدف: عدد نپر ( e = 2.71828 … ) را به توان يک عدد ميرساند.شکل تابع: Function Exp ( X: Real ): Real ; X عبارت يا متغيري از نوع اعشاري بوده و حاصل تابع نيز يک عدد اعشاري ميباشد اين تابع مقدار eبه توان X را محاسبه ميکند.
اسلاید 221: Var X : Real ; i : integer ; Begin For i : = 1 to 10 do Begin X : = exp ( i ) ; Writeln ( x : 8 : 2 ) ; End ;End . مثال :
اسلاید 222: تابع frac هدف: قسمت اعشاري يک عدد اعشاري را برميگرداند.شکل تابع: Function frac ( X: Real ): Real ; X عددي از نوع اعشاري و حاصل تابع يک عدد اعشاري که قسمت اعشاريعدد X است مي باشد و بعبارت ديگر اين تابع قسمت اعشاري عدد ورودي را به عنوان خروجي باز ميگرداند.
اسلاید 223: Var Y , X : Real ; Begin X : = frac ( 24.769 ) ; Y : = frac ( - 12.75 ) ; Write ( x = , 8 : 3 , y = , 8 : 2 ) ; End .مثال : خروجي : X = 0.769 Y = - 0.75
اسلاید 224: تابع Int هدف: قسمت صحيح يک عدد اعشاري را برميگرداند.شکل تابع: Function Int ( X: Real ): Real ; X يک عبارت يا متغير از نوع اعشاري و خروجي تابع فيزيک عدد اعشاري است اين تابع مقدار صحيح يک عدد اعشاري در خروجي نشان ميدهد.
اسلاید 225: Var y , x : Real ; Begin X : = Int ( 2.87 ) ; { 2.0 } Y : = Int ( - 8.76 ) ; { - 8.0 } End . مثال :
اسلاید 226: تابع Lnهدف: محاسبه لگاريتم يک عدد اعشاري در مبناي e.شکل تابع: Function Ln ( X: Real ): Real ; X يک عبارت يا متغير ازنوع اعشاري بوده وحاصل تابع فيزيک عدداعشاري ميباشد.
اسلاید 227: Var X : Real ; Begin X : = Ln ( 2.87 ) ; { x = 3.73767 } Write ( x = , x : 10 : 5 ) ; End . مثال :
اسلاید 228: تابع Odd هدف: فرد بودن عدد صحيح را بررسي مي کند.شکل تابع: Function odd ( X: logint ): Booleam ; X يک عبارت از نوع longint است و تابع ،فرد بودن عبارت را بررسي مي کند اگر مقدار خروجي تابع True باشد X فرد است و اگر مقدار خروجي تابع False باشد X فرد نيست.
اسلاید 229: Var i : integer ; Begin For i : = 1 to 100 do If odd ( i ) Then Writeln ( i = , j : 3 ) ; End . مثال :
اسلاید 230: تابع Ord هدف: غالباً براي پيدا کردن کد اسکي يک متغير کاراکتري بکار ميرود.شکل تابع: Function Ord ( x: char ): Longint ; عبارت x از نوع کارکتري را بعنوان پارامتر دريافت و کد اسکي آن را برمي گرداند. اگر x از نوع اسکالر باشد تابع بعنوان خروجي ترتيب قرار گرفتن x را در مجموعه اي که ابتدا به عنوان اسکالر اعلان شده، باز ميگرداند.
اسلاید 231: Var ch : char ; Begin For ch : = A to Z do Write ( ord ( ch ) : 5 ) ; End .مثال : کد اسکي A تا Z را درخروجي چاپ ميکند کد اسکي A عدد 65 ميباشد.خروجی :
اسلاید 232: تابع pi هدف: عدد پي را بر ميگرداند.شکل تابع: Function pi: Real ; اين تابع براي بازگرداندن عددي پي ( 3.141592 … ) مورد استفاده قرار ميگيرد.
اسلاید 233: تابع Pred هدف: مقدار قبل مقدار پارامتر را بر مي گرداند.پارامتر تابع مي تواند از هر نوع باشد و با توجه به نوع پارامتر تابع نياز از هم نوع ميباشد و خروجي تابع مقدار قبل از x ميباشد.Function pred ( x ): < same type of parameter > ; شکل تابع:
اسلاید 234: Ch: = pred ( d ) ; { ch = c }i: = pred ( 15 ) ; { i = 14 }flag: = pred ( True ) ; { flag = false } i: = pred ( - 30 ) ; { i = - 31 } مثال :
اسلاید 235: تابع Random هدف: براي توليد عدد تصادفي شکل تابع: Function Random: Real ; Function Random ( x: word ): word ; اگر تابع Random به شکل يک يعني بدون آرگومان مورد استفاده قرار گيرد يک عدد تساوي از نوع اعشاري بين صفر و يک توليد مي کند و اگر به شکل دو بکار رود باعث توليد يک عدد تصادفي از نوع word که بزرگتر يا مساوي صفر و کوچکتر از x است خواهد شد.
اسلاید 236: Var i : integer ; Begin For i : = 1 to 10 do Begin Writeln ( Random : 8 : 7 ) ; Writeln ( Random ) 20 ( : 8 ) ; End ;End . مثال : خروجی : 10 عدد تصادفي بين صفر و يک، و 10 عدد تصادفي بين 0 و 40 توليد نمايد.
اسلاید 237: تابع Round هدف: براي گرد کردن اعداد اعشاري بکار مي رود.شکل تابع: Function Round ( x: Real ): Longint ; X يک عبارت يامتغير اعشاري بوده وخروجي تابع يک عدد ازنوع Longint ميباشد که نتيجه گرد کردنX ميباشد. اين تابع X را به نزديکترين مقدارصحيح گرد ميکند.
اسلاید 238: i : = Round ( 57.4 ) { i = 57 } i : = Round ( 59.5 ) { i = 60 }i : = Round ( 12.7 ) { i = 13 }i : = Round ( 12.25 ) { i = 12 } i : = Round ( 17.75 ) { i = 18 } i : = Round ( 17.45 ) { i = 18 } i : = Round ( -2.5 ) { i = -3 } مثال :
اسلاید 239: تابع sqr هدف: براي محاسبه مجذور يک عدد صحيح يا اعشاري بکار ميرود.شکل تابع: Function sqr ( x: Integer ): Integer ; Function sqr ( x: Real ): Real ; X عبارتي يا متغييري از نوع صحيح يا اعشاري بوده و خروجي تابع فيزيک يک عدد صحيح يا اعشاري مي باشد اين تابع مجذور X را بعنوان خروجي بر ميگرداند.
اسلاید 240: Var i : integer ; Begin For i : = 1 to 10 do Writeln ( I ^ 2 = , sqr ( I ) ) ; End . مثال :
اسلاید 241: تابع sqrt هدف: براي محاسبه جذر يک عدد بکار ميرود.شکل تابع: Function sqrt ( x: Real ): Real ;X يک عبارت از نوع اعشاري بوده و خروجي تابع فيزيک عدد اعشاري ميباشد اين تابع جذر X را بعنوان خروجي بر ميگرداند.
اسلاید 242: Var Y , X : Real ; Begin Y : = sqrt ( 64 ) ; { y = 8 } Z : = sqrt ( 0.16 ) ; { z = 0.4 } Write ( x = , x : 8 : 2 , y = , y : 8 : 2 ) ; End .مثال :
اسلاید 243: تابع succ هدف: مقدار بعد از مقدار فعلي را برمي گرداند.شکل تابع: Function succ ( x ): same type of parameters ; X يک عبارت از نوع صحيح، اولين و غيره بوده و خروجي تابع نيز از همان نوع X مي باشد اين تابع مقدار بعد از X را بعنوان خروجي بر ميگرداند.
اسلاید 244: ch : = suce ( a ) { ch = b } ch : = suce ( A ) { ch = B } i : = suce ( 15 ) { i = 16 } flag : = suce ( false ) { flag = True }flag : = suce ( True ) { تعريف نشده } مثال :
اسلاید 245: تابع Trunc هدف: قسمت صحيح يک عدد اعشار را بر ميگرداند. شکل تابع: Function Trunc ( x: Real ): Longint ;X يک عبارت يا متغير از نوع اعشاري بوده و خروجي تابع يک عدد از نوع Longint ميباشد. اين تابع قسمت صحيح عدد اعشاري X را بعنوان خروجي بر ميگرداند.
اسلاید 246: Var x , i , j : Longint ; Begin i : = trunc ( 12.5 ) ; { i = 12 } j : = trunc ( 12.4 ) ; { i = 12 } k : = trunc ( 13.5 ) ; { k = 13 } Writeln ( I = , i : 5 , j = , j : 5 , k = , k : 5 ) ; End . مثال :
اسلاید 247: توابع از نوع کاراکتري در اين بخش توابعي را بررسي مي کنيم که خروجي آنها از نوع کاراکتري باشد. تابع chr هدف: معادل کاراکتري يک کد اسکي را بر ميگرداند.شکل تابع: Function chr ( X: Byte ): char ; X يک عبارت يا متغير از نوع بايت بوده و خروجي تابع يک کارکتر ميباشد. اين تابع کد اسکي را دريافت کرده و معادل کارکتري آن را بر ميگرداند.
اسلاید 248: Var i : Byte ; Begin For i : = 65 to 91 do Writeln ( chr ( I ) ) ; End . مثال : خروجی :برنامه بالا حروف A تا Z را در خروجي چاپ ميکند.
اسلاید 249: تابع Upcase هدف: براي تبديل يک کاراکتر به حرف بزرگتر بکار ميرود.شکل تابع: Function Upcase ( ch: char ): char ; ch يک عبارت يا متغير از نوع کاراکتر بوده و خروجي تابع فيزيک کاراکتري باشد اين تابع حرف کوچک را به حرف بزرگ تبديل کرده و بعنوان خروجي حروف بزرگ را بر ميگرداند.
اسلاید 250: مثال : Var Sent: array [ 1.. 80 ] of char ; i , N: Byte ;Begin Write ( enter Numbers: ) ; Readln ( N ) ; For i: = 1 to N do Read ( Sen [ i ] ) ; Writeln ; For i: = 1 to N do If ( sen [ i ] > = a ) and ( sen [ i ] < = z ) Then ; sen [ i ]: = Upcase ( sen [ i ] ) ; Writeln ( Out pot of program ) ; For i: = 1 to N do Writeln ( sen [ i ] ) ;End. { End of program }
اسلاید 251: روالهاي استاندارد در بخش هاي قبل ديديد که در توابع پارامترها به تابع ارسال مي شود و تابع نيز مقداري را بعنوان خروجي برميگرداند روالها نيز مشابه توابع عمل ميکنند با اين تفاوت که خروجي روالها از طريق پارامتر برميگردانده ميشود يا اعلان به سيستم عامل ميباشد. بنابراين روالها بدون نوع هستند. شکل کلي روالها بصورت زير ميباشد:Procedure Name ( Parameturs ) ; پارامترهاي روال اسم روال کلمه ذخيره شده
اسلاید 252: روال Dec هدف: يک يا چند واحد از پارامتر ارسالي کم مي کند.شکل روال: Procedure Dec ( Var X: longint ) ; Procedure Dec ( Var X: longint , N: longint ) ;X يک متغير از نوع longint و بصورت متغيري ميباشد اين روال يک واحد از پارامتر ارسالي کم ميکند.
اسلاید 253: Var N : integer Begin N : = 1201 ; Dec ( N ) ; { N = 1200 } Writeln ( N ) ; Dec ( N , 200 ) ; { W = 1000 } Writeln ( N ) ; End .مثال :
اسلاید 254: روال Exit هدف: کنترل برنامه را به خارج از بلوک جاري منتقل مي کند.شکل روال: Procedure Exit ; اين روال باعث مي شود که کنترل برنامه از بلوک جاري خارج شود. اگر اين روال در برنامه اصلي بکار رود باعث خروج از برنامه ميشود. و اگر در يک روال يا تابع بکار رود باعث خروج از روال يا تابع شده و کنترل برنامه به برنامه اصلي منتقل ميشود.
اسلاید 255: Var i , j : integer ;Begin i : = 100 ; j : = 20 ; Dec ( i , j ) ; Write ( i ) ; Exit ;End . مثال : خروجی :بعد از اتمام عمليات تابع Exit باعث خروج از برنامه مي شود.
اسلاید 256: روال Halt هدف: خاتمه دادن به اجراي برنامه شکل روال: Procedure Halt ; اين روال باعث خاتمه اجراي برنامه شده و کنترل برنامه به سيستم عامل بر ميگردد.
اسلاید 257: روال Inc هدف: اضافه کردن يک يا چند واحد به يک متغير شکل تابع:X يک عبارت يا متغير از نوع Longint مي باشد اين روال به مقدار متغير x يک يا چند واحد اضافه ميکند.Procedure Inc ( Var X: longint ) Procedure Inc ( Var X: longint , N: longint ) ;
اسلاید 258: Var N , i , j : integer ; Begin i : = 100 ; j : = 200 ; N : = 10 ; inc ( i ) ; { i = 101 } inc ( j , N ) ; { j = 210 } Writeln ( i = , i , j = , j ) ; End .مثال :
اسلاید 259: روال Randomize هدف: باعث تغير نحوه توليد اعداد تصادفي مي شود.شکل روال: Procedure Randomize ; وقتي در برنامه از تابع Random استفاده ميکنيم اعداد تصادفي توليد شده در اجراهاي مختلف يکسان مي باشد براي جلوگيري از اين وضعيت قبل از استفاده از تابع Random روال Rondomize را بکار ميبريم. تا باعث توليد اعداد تصادفي متفاوت در اجراهاي مختلف گردد.
اسلاید 260: Var i : word ;Begin Randomize; For i : = 1 to 10 do Writeln ( Random ( 50 ) ) ; End .مثال :
اسلاید 261: حل چند مثال برنامهنويسي مثال : برنامه اي بنويسيد که يک ماتريس مربع ( n < = 10 ) n * n از مقادير صحيح را از ورودي دريافت کرده آنگاه عناصري که مربع کامل نيستند را صفر کرده و در نهايت ماتريس حاصل را در خروجي چاپ مي کند.Var n , i , j : integer a : array [ 1 .. 10 , 1 .. 10 ] of integer ;Begin Write ( enter Number : ) ; For i : = 1 to N do For j : = 1 to N do Read ( a [ i , j ] ) ;
اسلاید 262: For i : = 1 to N do For j : = 1 to N do If a [ i , j ] sqr ( Trunc (sqrt (Abs ( a[ i , j ] ))) ) < > 0 Then a [ i , j ] : = 0 ; Writeln ( The oupput Mafrix ) ; For i : = 1 to N do Begin For j : = 1 to N do Write ( a [ i , j ] : 5 ) ; Writeln ; End ;End . { End of program }
اسلاید 263: مثال : برنامهاي بنويسيد که يک جمله از ورودي دريافت کرده سپس حروف بزرگ جمله را به حروف کوچک تبديل نمائيد.Var sen : array [ 1 .. 80 ] of char ; Ch : char ; i : word ; Begin Write ( enter sentence ) ; Repeat Read ( sen [ i ] ) ; Inc ( i ) ; Until sen [ i ] = . ; Writeln ; n : = Dec ( i ) ; For i : = 1 to n do If ( sen [ i ] > = A ) and ( sen [ i ] < = B ) Then sen [ i ] = chr ( ord ( sen [ i ] ) + ( ord ( a ) – ord ( A )) ) Writeln ( The result sentence ) ; For i : = 1 to n do Write ( sen [ i ] ) ;End . { End of program }
اسلاید 264: تمرينات خروجي تمرينات زير را تعيين کنيد:a) Var i , j : integer Begin i : = 100 ; j : = 20 ; inc ( i ) ; Dec ( j , 10 ) ; inc ( i , j ) ; Writeln ( i : 5 , j : 5 ) ; End .b) Var y : integer ; Begin y : =Round ( 18.31 ) MoD 5 ; Writeln ( y ) ; End .
اسلاید 265: .2خروجي دستورات زير را محاسبه نمائيد:a) Ch: = A ; Ch: = chr ( ord ( ch ) + 3 ) ; Write ( ch ) ; b) X: = 12 ; Succ ( x ) ; Ch: = B ; Pred ( ch ) ; Write ( x , ch ) ;
اسلاید 266: تمرينات برنامهنويسي 1- برنامهاي بنويسيد که تعداد 1000 شماره حساب بانکي 7 رقمي بطور تصادفي بين 5119432 و 9981711 را توليد کرده و چاپ کند.2- برنامه اي بنويسيد تا تعداد 38 عدد تصادفي صحيح بين 10 تا 99 راتوليد کرده، سپس آن را در خروجي به شکل مربع وسط صفحه نمايش چاپ کند.3- برنامهاي بنويسيد که يک عدد 20 رقمي از ورودي دريافت کرده آن را در يک عدد تک رقمي ضرب نموده و حاصل را در خروجي چاپ نمائيد.
اسلاید 267: فصل 10(String) متغيرهاي كاراكتري و رشتههاهدفهاي كلي بررسي ساختار آرايه هايي از نوع كاراكتر معرفي نوع دادة جديد به نام رشتهمقايسه آرايه اي از كاراكتر و رشته شناخت توابع و روالهاي استاندارد براي رشته ها
اسلاید 268: ÷ هدفهاي رفتاري آرايهاي از كاراكترها را در برنامه بكار ببرد. آرايهاي از كاراكترها را با رشته مقايسه كند. اسمي افراد و غيره را با استفاده از آرايهاي از رشته مرتب نمايد. توابع و روالهاي استاندارد مربوط به رشتهها را در برنامه خود بكار ببرد.دانشجو پس از مطالعه اين فصل بايد بتواند:
اسلاید 269: متغيرهايي از نوع کاراکتر متغيرهاي کاراکتري ظرفيت پذيرش يک کاراکتر ( شامل يک رقم، يک حرف از حروف و يا يک کاراکتر ديگر ) را دارا ميباشند.: مقدار دهي اين متغير ها به صورت زير ميباشدch: = A ; اگر بخواهيم متغير هاي کاراکتري را از ورودي بخوانيم بايد دقت بيشتري به .خرج دهيم براي اينکه فضاهاي خالي کاراکتر محسوب مي شوند
اسلاید 270: مثال : خروجي قطعه برنامه زير را تعيين کنيد. Ch: = A ;C: = a ;If ch = c Then Writeln ( equal ) Else Writeln ( Not equal ) ;خروجي حاصل از قطعه برنامه بالا بصورت زير است: Not equal
اسلاید 271: درکل ميتوان کاراکترها را از لحاظ اردينال (مرتبه) بصورت زير دستهبندي کرد: 1- رقم ها بصورت زير مقايسه ميشوند: 0 < 1 < 2 < 3 < … < 9 رقمها از لحاظ کد اسکي پشت سر هم قرار گرفتهاند. 2- حروف بصورت زير مقايسه مي شوند: A < B < … < Z < … < a < b < … < z
اسلاید 272: متغيرهاي رشتهاي ( String ) تعريف: مجموعهاي از کاراکتر را يک رشته ناميده و متغير از نوع آن را يک متغير رشتهاي مينامند.اين متغير نيز مانند ساير متغيرها در قسمت تعاريف متغيرها ( Var ) معرفي ميشود. در تعريف يک متغير رشتهاي معمولاً طول آن را مشخص ميکنند. اگر طول تعيين نشود بطور قراردادي کامپايلر حداکثر طول را براي آن در نظر ميگيرد. حداکثر طول رشته 255 کاراکتر ميباشد.
اسلاید 273: نحوه تعريف متغير رشته اي بصورت زير ميباشد: Name : string [ length ] طول رشته کلمه ذخيره شده اسم رشته
اسلاید 274: متغيرهاي رشتهاي را بصورت زير ميتوان مقداردهي کرد: Var S : string [ 10 ] ; . . .Begin . . S : = pascal ; Write ( s ) ; . . End .
اسلاید 275: براي خواندن متغيرهايرشتهاي ازدستورRead يا Readln بصورت زيرميتواناستفاده کرد:Read ( s ) ; هنگام خواندن متغيرهاي رشتهاي اگر طول رشته ورودي از طول تعريف شده بيشتر باشد فقط به اندازه طول تعريف شده خوانده مي شود و اگر طول رشته ورودي کمتر از طول تعريف شده باشد، رشته ورودي در منتهياليه سمت چپ متغير رشتهاي قرار گرفته و بقيه متغير رشته اي بدون محتوا باقي مي ماند،
اسلاید 276: براي چاپ يک متغير رشتهاي نيز ازدستور Write يا Writeln ميتوان استفاده کرد: Write ( s ) ;مثال : برنامهاي بنويسيد که شماره دانشجوئي، اسم و فاميل دانشجوئي را از ورودي دريافت کرده سپس در خروجي نمايش دهد.
اسلاید 277: Var Name , family: string [ 40 ] ; Id: longintBegin writeln ( Enter student number ) ; Readln ( Id ) ; writeln ( Enter Name ) ; Readln ( Name ) ; writeln ( Enter family ) ; Readln ( family ) ; writeln ( Id Name Family ) ; writeln ( Id: 7 , Name , Family ) ; End.
اسلاید 278: آرايهاي از رشته بصورت زير تعريف ميشود: Name : Array [ 1 .. length ] of string نوع رشته اي طول آرايه اسم آرايه
اسلاید 279: براي خواندن چنين آرايهاي بصورت زير عمل ميکنيم:For i : = 1 to 50 do Readln ( Name [ i ] ) ; براي نمايش آرايه در خروجي بصورت:For i: = 1 to 50 do Writeln ( Name [ i ] )
اسلاید 280: مثال : برنامهاي بنويسيد که اسم 10 نفر از ورودي دريافت کرده و آنها را برحسب حروف الفبا مرتب نمايد. Var Name : Array [ 1 .. 10 ] of string [ 10 ] ; string [ 10 ] ; temp : i , j : Byte;Begin writeln ( Enter Ten Names ) ; for i : = 1 to 10 do Readln ( Name [ i ] ) ; for j : = 1 to 9 do for j : = i +1 to 10 do if Name [ i ] > Name [ j ] Then Begin Temp : = name [ i ] ; Name [ i ] : = Name [ j ] ; Name [ j ] : = temp ; End ; { sort Algrithm } writeln ( The sorted list ) ; for i : = 1 to 10 do writeln ( Name [ i ] ) ; end . { End of program }
اسلاید 281: مثال : برنامهاي بنويسيد که اسم، فاميلي و شماره دانشجوئي حداکثر 50 دانشجو را از ورودي دريافت نمايد.سپس با خواندن اسمي از ورودي، ساير اطلاعات اسم خوانده شده را در صورت وجود در خروجي نمايش دهد.Var Name , Family : array [ 1 .. 50 ] of string [ 30 ] ; id : array [ 1 .. 50 ] of longint ; Nam : string [ 30 ] ;
اسلاید 282: Begin write ( Enter Number : ) ; Readln ( N ) ; for i : = 1 to N Do Begin write ( Enter Name : ) ; Readln ( Name ) ; write ( Enter family : ) ; Readln ( family ) ; write ( Enter student Number : ) ; Readln ( Id ) ; end ; writeln ; write ( Enter Name : ) ; Readln ( Nam ) ; i := 0 ; flag : = Ture ;
اسلاید 283: while ( i < = n ) and flag Do Begin inc ( i ) ; if Name [ i ] = Nam then flag : = false ; end ; If flag then writeln ( Not found ) ; Else Begin writeln ( Id Name family ) write ( Id , Name : 30 , family : 30 ) ; end ; End . { End of program }
اسلاید 284: توابع و روالهاي کتابخانهاي براي متغيرهاي رشتهاي تابع Concat هدف: الحاق دو يا چند رشته به يکديگر شکل تابع: Function concat ( S1 , S2 , … , Sn ): string ; Sn , … , S2 , S1 متغيرهايي از نوع رشته هستند و خروجي تابع نيز يک متغير رشتهاي است اين تابع دويا چندتابع را به هم پيوند داده، و رشته حاصل را برميگرداند.
اسلاید 285: : مثال Var Str3 , str1 , str2 : string Begin Str1 : = Pascal ; Str2 : = Book ; Str3 : = Concat ( Str1 , Str2 ) ; write ( Str3 ) ; End.با اجراي برنامه فوق، عبارت Pascal Book نشان داده خواهد شد.
اسلاید 286: تابع Copy هدف: استخراج يک زير رشته ( substring ) از يک رشته شکلتابع:Function copy (S:string ; Index:Integer; count: Integer): string; S يک عبارت يا متغير رشته اي که مي خواهيم از آن زير رشته اي که نقطه شروع آن Index و طول آن Count مي باشد جدا کنيم. لذا زير رشته حاصل، يک رشته که طول آن به اندازه Count است، ميباشد.
اسلاید 287: : مثال Var Str , str1: string ; Begin Str: = Pascal Book ; Str1: = Copy ( Str , 7 , 4 ) ; { Str1 = Book } write ( Str1 ) ; End.
اسلاید 288: روال Delete هدف: حذف يک زير رشته از يک رشته شکلروال:Procedure delete (Var str: string; Index:integer;length: integer ) ; Str يک متغر رشته اي، Index يک عبارت يا متغير صحيح و Length نيز يک عبارت يا متغير صحيح ميباشد. روال Delete يک زير رشته را از يک رشته حذف ميکند اين روال از محل Index بطول Length از رشته Str حذف ميکند و رشته حاصل بعنوان خروجي روال برگردانده ميشود.
اسلاید 289: : مثال Var St : string ; Begin St: = Pascal.Book ; Delete ( St , 7 , 5 ) ; writeln ( St ) ; End. خروجي حاصل از برنامه فوق Pascal ميباشد.
اسلاید 290: روال Insert هدف: درج ( وارد کردن ) يک رشته در يک رشته ديگر شکل روال: Procedure Insert ( Str1: string ;Var Str2: string ; Index: Byte ) ; Str1 عبارت يا متغير رشته اي، Str2 متغير رشته اي و Index عبارتي عدد از نوع صحيح ميباشد. روال Insert ، رشته Str1 رادر رشته Str2 از خانه Index درج ميکند و رشته حاصل خروجي روال خواهد بود.
اسلاید 291: : مثال Var Str1 , str2: string ; Begin Str1: = Pascal 7 ; Str2: = Turbo ; Insert ( Str1 , Str2 , 6 ) ; End. خروجي حاصل از برنامه بالا Turbo pascal 7 خواهد بود.
اسلاید 292: تابع Length هدف: محاسبه طول رشته شکل تابع: Function length ( Str: string ): Integer ; Str يک عبارت رشته اي بوده و خروجي تابع يک عدد صحيح ميباشد. اين تابع طول رشته ورودي را محاسبه و بعنوان خروجي بر ميگرداند.
اسلاید 293: : مثال Var St: string ; n: integer ; Begin St: = Turbo Pascal 7 ; n: = length ( S4 ) ; { n = 14 } Write ( The length of string is: , n ) ; End.
اسلاید 294: تابع Pos هدف: براي جستجوي يک رشته داخل رشته ديگر شکل تابع: Function pos ( Str1: string ; Str2: string ): Byte ; Str1 يک عبارت يا متغير رشته اي و Str2 نيز يک عبارت يا متغير رشته اي ميباشد و خروجي تابع يک عدد صحيح مي باشد. اين تابع محل اولين وقوع رشته Str1 در رشته Str2 را بعنوان خروجي بر ميگرداند.
اسلاید 295: : مثال Var Str1 , Str2: string ; i: integer ; Begin Str1: = Book ; Str2: = Pascal Book ; i: = Pos ( Str1 , Str2 ) ; { i = 8 } Write ( i = , i ) ; End. نکته: توجه کنيد که اگر عمل جستجو با موفقيت انجام نشود ( يعني رشته اول در رشته دوم وجود نداشته باشد ) تابع مقدار صفر بر ميگرداند.
اسلاید 296: روال Str هدف: براي تبديل عدد به يک رشته عددي بکار مي رود.درشکل 1، I يک عبارت يا متغيرعددي بوده و Str يک متغير رشتهاي ميباشد اين روال يک عدد صحيح با فرمت مشخص را به يک رشته عددي تبديل مي کند.درشکل 2 ، F يک عبارت يا متغير رشتهاي و Str يک متغير رشتهاي ميباشد.شکل روال: 1: Procedure Str( I: integer: format , Str: string ) ; 2: Procedure Str ( F: Real: format , Str: string ) ;
اسلاید 297: : مثال Var Number , Str: String ;Begin Str ( 543: 5 , Str ) ; { Str = 543 } Str ( 12.25: 7: 2 ,Str ) ; { Str = 12.25 } Str ( 127: 3: Str ) ; { Str = 127 } Str ( 3.1239: 7: 3 , Str ) ; { Str = 3.124 }End.
اسلاید 298: روال Val هدف: تبديل يک رشته عددي به يک عددS يک عبارت يا متغير رشته اي، N يک متغير از نوع صحيح يا اعشاري و Error نيز يک متغير از نوع صحيح مي باشد. اين روال يک رشته عددي را به يک عدد صحيح يا اعشاري تبديل مي کند و آن را توسط متغير N برميگرداند. اگر عمل تبديل بطور صحيح انجام شود، مقدار متغير Error برابر صفر در غير اينصورت محل وجود اشکال را مشخص ميکند.شکل روال: 1: Procedure Val ( S: String ; Var N: integer ; Var Error: integer ) ; 2: Procedure Val ( S: String ; Var N: Real ; Var Error: integer ) ;
اسلاید 299: : مثال Var St: string ; E , N: integer ; F: Real ;Begin St = 475 ; Val ( St , N , E ) ; { N = 475 , E = 0 } St = 475 ; Val ( St , F , E ) ; { F = , E = 3 } St = 3.1716 ; Val ( St , F , E ) ; { F = 3.1716 , E = 0 }End.
اسلاید 300: ارائه چند مثال در مورد رشتهها و کاراکترها مثال : برنامهاي بنويسيد که يک جمله از ورودي دريافت کرده سپس در صورتي که کلمه IS وجود داشته باشد آنها را به are تبديل نمايد و در نهايت رشته حاصل را در خروجي نمايش دهد.توجه کنيد که ممکن است بيش از يک بار کلمه IS تکرار شده باشد در اينصورت همه کلمات IS را با are تبديل کند.
اسلاید 301: Var St : string ; Begin Writeln ( Enter sentence ) ; Readln ( St ) ; Repeat i : = Pos ( is , St ) ; if i > 0 Then Begin Delete ( St , i , 2 ) ; Insert ( are , St , i ) ; end ; Until i = 0 ; Writeln ( The result sentence ) ; Write ( St ) ; End . { End of program }
اسلاید 302: مثال : برنامهاي بنويسيد که يک رشته از ورودي دريافت کرده، سپس معکوس رشته را بدست آورده بهمراه خود رشته در دو سطر جداگانه چاپ نمايد. Var St1 , St2 : string ; i , j : integer ;Begin Writeln ( Enter sentence ) ; Readln ( St1 ) ; j : = 1 ; For i : = length ( St1 ) downto 1 do Begin St2 [ j ] : = St1 [ i ] ; Inc ( j ) ; End ; Writeln ( The result ) ; Writeln ( St1 ) ; Writeln ( St2 ) ; End . { End of program }
اسلاید 303: تمرينات با فرض اينکه S3 , S2 , S1 متغير هاي رشته اي هستند خروجي عبارتهاي زير را تعيين کنيد.a)S3 = copy ( S1 , 1 , 6 ) ; b)S3 = concat ( S3 , S2 , S1 ) ;c)S3 = copy ( S2 , 1 , pos( S1 , S2 ) – 1 ) ;d)Delete ( S2 , pos( S1 , S2 ) , length ( S1 ) ) ;
اسلاید 304: خروجي قطعه برنامه زير را تعيين کنيد: Var S1: string ; i: integer ;Begin S1: = ABCDEF ; For i: = 1 to length ( S1 ) ; Delete ( S1 , i , 1 ) ; Writeln ( S1 ) ;.End
اسلاید 305: خروجي قطعه برنامه زير را تعيين کنيد: Var St: string ; i: integer ;Begin Readln ( St ) ; For i: = 1 to length ( St ) Do If ( St [ i ] > = 0 ) and ( St [ i ] < = 9 ) then Delete ( St , i , 1 ) ; Writeln ( St ) ;.End
اسلاید 306: Insert ( S1 , S2 , pos ( S1 , S2 ) ) ; S3 : = copy ( S2 , pos ( S1 , S2 ) , length ( S1 ) ;S3 : = copy ( S2 , pos ( St , S2 ) , length ( S2 ) ; Delete ( S1 , pos ( S2 , S1 ) , length ( S2 ); e) S1 [ 0 ] := # 6 ; با فرض اينکه S2 = Book , S1 = pascal Book هستند خروجي عبارت زير را تعيين کنيد.
اسلاید 307: تمرينات برنامهنويسی برنامهاي بنويسيد که يک پاراگراف را از ورودي دريافت کرده ( حداکثر 10 خط ) سپس:الف) تعداد کلمات هر سطر را شمرده و انتهاي سطر نمايش دهد.ب) تعداد حروف صدا دار را شمرده چاپ نمايد.ج) تعداد خطوط برنامه را شمرده در خروجي چاپ کند.د) تعداد جملات هر خط را محاسبه و در سطر هاي جداگانه نمايش دهد.
اسلاید 308: برنامهاي بنويسيد که يک عدد در مبناي مشخص را از ورودي دريافت کرده سپس آن را به مبناي m که از ورودي خوانده مي شود ببرد.برنامهاي بنويسيد که يک پاراگراف را از ورودي دريافت کرده کلمات تکراري هر سطر را حذف نموده و پاراگراف حاصل را بهمراه پاراگراف اوليه در خروجي با پيغام مناسب نمايش دهد.
اسلاید 309: برنامهاي بنويسيد که دو عدد 20 رقمي ( بصورت رشته بايد خوانده شود ) را از ورودي دريافت کرده سپس مجموع و حاصل ضرب اين دو عدد را محاسبه و در خروجي با پيغام مناسب چاپ نمايد.برنامهاي بنويسيد که يک رشته از ورودي دريافت کرده سپس کلمات داخل آن را بصورت عمودي کاراکتر به کاراکتر نمايش دهد:برنامهاي بنويسيد که يک پاراگراف با حداکثر 5 خط را از ورودي دريافت نمايد. سپس مجموع ارقام يا اعداد ( در صورت وجود ) هر خط را محاسبه نموده در انتهاي همان سطر نمايش دهد.
اسلاید 310: فصل 11برنامههاي فرعيهدفهاي كلي شناخت اجزاء تشكيلدهنده توابع و روالها بررسي انواع پارامترها و متغيرها در برنامههاي فرعي شناخت تفاوتهاي روالها و توابع معرفي مزاياي استفاده از زير برنامهها
اسلاید 311: ÷ هدفهاي رفتاري برنامه خود را به چندين زيربرنامه تقسيمبندي نمايد. زيربرنامهها را با توجه به قوانين موجود، در ساختار برنامه جا دهد. باتوجه به مزاياي استفاده از آنها را در برنامه خود بكار ببرد. دانشجو پس از مطالعه اين فصل بايد بتواند:
اسلاید 312: روالها روالها نوعي از برنامههاي فرعي هستند، که به طور مستقل و جداگانه وظيفه يا وظايف خاصي از برنامه اصلي را انجام ميدهند. روال ها در صورت نياز اطلاعات خود را از طريق پارامترها دريافت و همچنين در صورت نياز نتايج را از طريق پارامترها به برنامه اصلي باز ميگردانند. پارامترها در حقيقت خطوط ارتباطي بين برنامه اصلي و برنامههاي فرعي هستند. پارامترها باعث مي شوند، که توابع و روال ها روانتر عمل کنند، زيرا آنها به برنامه هاي فرعي اين قابليت را مي دهند که با هر فراخواني، دادههاي مختلفي را مورد پردازش قرار دهند.
اسلاید 313: شکل کلي روالها بصورت زير مي باشد: Procedure Name ( parameters list ) ; ليست پارامترها اسم روال کلمه ذخيره شدهVar { List of locad variable }Begin . . { Procedure Body } . .End ; { End of procedure }
اسلاید 314: در حالت کلي روال ها در برنامه اصلي بصورت زير ظاهر ميشوند:; اسم برنامه اصلي Program ; تعاريف برنامه اصلي Procedure ..... ; Begin { main program } . . . فراخواني روال ها . .End. { End of program }
اسلاید 315: پارامترها با توجه به محل وقوع آنها به دو دسته تقسيم مي شوند:پارامترهاي صوري ( Formal parameters ) .2پارامترهاي واقعي ( Actual parameters ) از پارامترهاي صوري هنگام اعلان روال و از پارامترهاي واقعي هنگام . فراخواني روال ها استفاده ميشود
اسلاید 316: پارامترهاي صوري در حالت کلي 2 نوعند، که با توجه به نوع روال و تصميم برنامه نويس مورد استفاده قرار مي گيرند: پارامترهاي مقداري ( Value parameters ) پارامترهاي متغيري ( Variable parameters )
اسلاید 317: پارامترهاي مقداري ( Value parameters ) پارامترهاي مقداري، پارامترهايي هستند که مقدار متغيرهاي فرستاده شده از برنامه اصلي را دريافت مي کنند و وظيفه آنها فقط عبور دادن مقدار به روال ميباشد. لذا تغیيرات پارامترهاي مقداري در روال به برنامه اصلي انتقال نمييابد: پارامترهاي مقداري بصورت زير تعريف مي شوندProcedure Name ( var1 : type ; var2 : type , . . . . ) ; ليست پارامترهاي از نوع مقداري اسم روال کلمه ذخيره شده
اسلاید 318: مثال : به برنامه زير توجه کنيد:Program main ;Var x1 , x2 , y1 , y2 : integer ;Procedure test (A1,A2,B1,B2:integer);{formal parameters } ......Begin { main } .... test ( x1 , x2 , y1 , y2 ) ; { Actual parameters } ...... End. { End of program }
اسلاید 319: نکته: پارامترهايي که در روال بکار برده مي شود، هيچ ارتباطي به پارامترهاي ارسالي از برنامه اصلي ندارند و فقط مقادير اين متغيرها از برنامه اصلي ارسال مي شود. لذا اسامي پارامترهاي صوري ممکن است هم اسم با پارامترهاي واقعي برنامه اصلي انتخاب شوند، اين به معناي اين نيست که اين پارامترها ( پارامترهاي صوري ) همان پارامترهاي واقعي هستند.در مثال بالا اين تناظر برقرار است:پارامترهاي واقعي متناظر است با پارامترهاي صوريX1 A1X2 A2Y1 B1Y2 B2
اسلاید 320: متغيرهاي … , Var2 , Var1 پارامترهاي مقداري هستند. توجه کنيد، که اين پارامترها صوري هستند و نوع و ترتيب آنها بايد با نوع و ترتيب پارامترهاي واقعي در تناظر يک به يک باشند.
اسلاید 321: مثال : به برنامه زير توجه کنيد:Program main ;Var x1 , x2 , y1 , y2 : integer ;Procedure test ( A1 , A2 , B1 , B2: integer ); {formal parameters } ......Begin { main } .... test ( x1 , x2 , y1 , y2 ) ; { Actual parameters } ...... End. { End of program }
اسلاید 322: همانطور که ملاحظه مي کنيد، روالي بنام test با 4 پارامتر مقداري در برنامه استفاده شده است. متغيرهاي y2 , y1 , x2 , x1 از برنامه اصلي به روال test ارسال شده و بترتيب مقادير اين متغيرها در متغيرهاي با همان نوع در B2 , B1 , A2 , A1 قرار مي گيرند.
اسلاید 323: پارامترهاي متغيري ( Variable parameters ) يك پارامتر متغيري، تغييرات يك پارامتر واقعي را بعنوان خروجي به برنامه اصلي برميگرداند. تفاوت اين گونه پارامترها با پارامترهاي مقداري در ارسال تغييرات ايجاد شده در پارامترها ميباشد. وقتي نياز است، كه نتايج روال به برنامه اصلي برگردد، از پارامترهاي متغيري استفاده ميكنند. اعلان پارامترهاي متغيري به صورت زير ميباشد: procedure Name ( var id1 : type ; var id2 : type , … ); ليست پارامترهاي متغيري اسم رواال كلمه ذخيره شده متغيرهاي id1 , id2 و … پارامترهاي متغيري ميباشند كه نتايج روال، توسط آنها به برنامه اصلي بازگردانده ميشود.
اسلاید 324: مثال : روالي بنام ComputeSumAve بنويسيد كه مجموع و ميانگين دو عدد را محاسبه و نتيجه را در برنامه اصلي چاپ نمايد.Program Example;Var Num1, Num2: integer; Total,average: Real;Procedure ComputeSumAve(Num1 , Num2: integer ; Var sum , ave : Real); Begin Sum:=Num1+Num2; Ave:=sum/2;End; {End of procedure}Begin {Main} WriteLn( Enter Two Numbers);ReadLn(Num1,Num2); ComputeSumAve (Num1, Num2, total, average); WriteLn(The Sum is= , sum:8:2 , The average is= , average:8:2);End. {End of program }
اسلاید 325: پارامترهاي واقعي و صوري عبارتند از:پارامتر واقعي متناظر است با پارامترهاي صوريNum1 Num1Num2 Num2Total sumAverage aveNum1 , Num2 پارامترهاي مقداري و sum , ave پارامترهاي متغيري ميباشند، كه توسط آنها نتايج به برنامه اصلي برگردانده ميشود.
اسلاید 326: متغيرهاي محلي و سراسري ( Local and Global Variable) در برنامههاي فرعي دو نوع متغير علاوه از پارامترها مورد استفاده قرار ميگيرند. اين متغيرها متغيرهاي محلي يا متغيرهاي سراسر هستند.متغيرهاي محلي، متغيرهايي هستند كه در بلاك مربوط به خود قابل استفاده هستند. ولي متغيرهاي سراسري در تمام برنامههاي فرعي قابل دسترس ميباشند.متغيرهاي محلي در داخل برنامههاي فرعي در قسمت تعاريف معرفي ميشوند و در خارج از روال قابل دسترسي نيستند.
اسلاید 327: مثال : روالي براي محاسبه مجموع و ميانگين دو عدد بنويسيد.Procedure CalcSumAve ( Num1 , Num2: Read );Var Sum , Ave: Real ;Begin Sum:= Num1 + Num2 ; Ave:= Sum / 2 ; WriteLn( The Sum is = , sum:8:2 ) ; WriteLn( The average is =,ave:8:2);End;{End of procedure}
اسلاید 328: در مثال بالا sum , Ave متغيرهاي محلي ميباشند. براي فراخواني روال CalcSumAve(x.y); كه درآن x.y دو متغير ازنوع Real ميباشند. به شكل زيرتوجهكنيد:پارامترهاي واقعيX Y پارامترهاي صوريNum1 Num2 متغيرهاي محلي Sum Ave
اسلاید 329: مثال : خروجي برنامه زير را تعيين كنيد.Program Example6;Var A , b , c: integer ; {Global Variables}Procedure test(var b: integer ; a: integer );Var D: integer ; {local variable}Begin D:= 12 ; a:= b + d ; b:= a + c ; c:= c+ 2 ;End;Begin {Main} A:=1; b:=2; c:=3; Test(a,b); WriteLn( a = , a , b = , b , c = , c ) ;End.{End of program}خروجي برنامه بالا بصورت زير است:a =16 b=2 c=5
اسلاید 330: روالها معمولاً به سه شكل ظاهر ميشوند: بكارگيري روالهاي بدون پارامتر بكارگيري روال همراه پارامترهاي با خاصيت ورودي بكارگيري روال همراه پارامترهاي با خاصيت ورودي و خروجي
اسلاید 331: بكارگيري روالهاي بدون پارامترگاهي لازم است تا برنامه فرعي كاملاً مستقل (بينياز از مقادير برنامه اصلي) در بخشهاي مختلف يك برنامه اجرا شود. در اين صورت نياز به استفاده از پارامتر بيمفهوم ميباشد و از روالهاي بدون پارامتر استفاده ميكنند.غالباً زمانيكه بخواهيم پيغامهاي خاصي را در قسمتهاي مختلف برنامه نمايش دهيم، اين پيغامها را در يك روال قرار داده و در صورت نياز، روالمربوطه را فراخواني ميكنيم.
اسلاید 332: مثال : روال Head بدون دريافت پارامتري فراخواني ميشود.Program Example ;Procedure Head ; Begin WriteL(Name Family Age No); WriteLe(……………………………...); End;Begin{Main} WriteLn( open university ) ; Head;End.
اسلاید 333: بكارگيري روال همراه پارامترهاي با خاصيت ورودي همانطور كه قبلاً اشاره كرديم، هدف از بكارگيري پارامترها انتقال مقادير از برنامه اصلي به روالها ميباشد. اگر اين انتقال يك طرفه باشد يعني فقط از برنامه اصلي به روال باشد، اين نوع پارامترها فقط خاصيت ورودي خواهند داشت. (قبلا در اين مورد توضيح داده شده است) در اين نوع روالها از پارامترهاي مقداري استفاده ميكنند.
اسلاید 334: مثال : روالي بنويسيد كه توسط آن مربعات اعداد1 تا N را درخروجي چاپ نمايد.Program Example ;Var N , I: integer ; Procedure sq ( M: integer ) ; Begin WriteLn ( sqart is = , M * M ) ; End;Begin {Main} Write( Enter Number = ) ; RealLn ( N ) ; For I:= 1 to N do Sq (i) ;End. {End of program}
اسلاید 335: بكارگيري روال همراه پارامترهاي با خاصيت ورودي و خروجي در اين نوع روالها پارامترها دو خاصيت مهم دارند يكي انتقال دادهها از برنامه اصلي به روال و ديگري انتقال يا ارجاع نتايج از روال به برنامهاصلي ميباشد. در اين نوع روالها از پارامترهاي متغيري استفاده ميكنند.
اسلاید 336: مثال : روالي بنام change بنويسيد كه توسط آن دوعدد بعنوان پارامتر دريافت كرده، مقادير اين دو متغير را جابجا نموده و نتيجه را در برنامه اصلي چاپ نمايد.Program Example ;Var A , b: integer ;Procedure change (var x , y: integer) ;var temp:integer;Begin Temp:=x; X:=y; Y:=temp;End;
اسلاید 337: Begin { Main } ReadLn( a , b ) ; Change( a , b ); WriteLn ( a= , a , b= , b ) ;End.{End of program}
اسلاید 338: ارتباط روالها با يكديگر در پاسكال زير برنامهها نه تنها از طريق برنامه اصلي بلكه از داخل يكديگر نيز .فراخواني ميشوندفراخواني روالها از داخل يكديگر تابع قوانين كلي زير است: قانون اول قانون دوم قانون سوم
اسلاید 339: قانون اول از هر برنامه (اصلي يا فرعي) به برنامه فرعي در صورتي ميتوان، دسترسي داشت، كه در بخش تعاريف آن برنامه (اصلي يا فرعي) قرار داشته باشد. بطور مثال در شكل زير برنامه اصلي M ميتواند، به كليه برنامههاي فرعي p1,p2 و… كه در بخش تعاريف برنامه اصلي قرار دارند، مراجعه كند
اسلاید 340: Main . . . .Proc1Proc2ProcN برنامه اصليبرنامه هاي فرعي
اسلاید 341: مثال : به برنامه زير توجه كنيد:program Main;var ……..procedure proc1;var ……..Begin ………End;Procedure proc2;Var ………Begin ……end;Begin {Main} Proc1; Proc2;End.
اسلاید 342: روالهاي proc1 , proc2 داخل برنامه اصلي Main تعريف شدهاند. لذا براحتي ميتوان در برنامه اصلي به آنها دسترسي پيدا كرد. روالها خود نيز داخل هم ميتوانند قرار بگيرند. دقيقاً مثل روالهاي معمولي با اين تفاوت كه در داخل روال بايد تعريف شوند. به اينگونه روالها، اصطلاحاً روالهاي متداخل يا تودرتو ميگويند.
اسلاید 343: اگر روالها در بخش تعاريف يك برنامه به موازات يكديگر تعريف شوند و نه در داخل هم، در روالهاي بعدي امكان رجوع به روالهاي قبلي وجود خواهد داشت. بعبارت ديگر به روالي ميتوان دسترسي پيدا كرد كه قبلاً تعريف شده باشد. قانون دوم
اسلاید 344: بطور مثال اگرp1,p2,p3 سه روال باشند دراينصورت ميتوان بصورت زيرعمل كرد: Main P1P2P3 P2روال هابرنامه اصليدر شكل بالا چون p2 قبلاً معرفي شده است ميتوان آنرا داخل p3 فراخواني كرد.
اسلاید 345: اگر روالها در بخش تعاريف برنامهأي بصورت متداخل باشند، در اينصورت از روال دروني ميتوان به روالهاي بيروني كه قبلاً تعريف شده، مراجعه كرد و همچنين از روال دروني به روالهاي بيروني كه به موازات يكديگر قرار گرفتهاند، نيز ميتوان دسترسي پيدا كرد. بطور مثال در شكل زير روال p1 ميتواند به روالهاي p2,p3 دسترسي پيدا كند. وهمچنين روال دروني p4 ميتواند بهروالهاي p2 , p3 مراجعه كند. قانون سوم
اسلاید 346: Main P3P2P1روال هابرنامه اصلي
اسلاید 347: اعلان روالها به روش forward همانطور كه قبلاً اشاره كرديم از روالي ميتوان در روال ديگر استفاده كرد، كه قبلاً تعريف شده باشد. در توربوپاسكال نقيصه فوق به كمك اعلان forward قابل حل است. بدين صورت كه اگر روالي به هنگام تعريف با اعلان forward همراه باشد، بدون رعايت از پيش تعريف شدن ميتواند، در روالهاي ديگر ظاهر شود.
اسلاید 348: شكل اعلان به روش forward بصورت زير ميباشد:Procedure Name ( parameters ) ; forward ; كلمه ذخيره شده ليست پارامترها اسم روال كلمه ذخيره شده
اسلاید 349: مثال :Program forward_Main ;Var ………Procedure proc3 ; forward ;Procedure proc1;var ……..Begin ………end;Procedure proc2;var ………Begin ……… proc3; ……end;
اسلاید 350: Procedure proc3;var ……..Begin …….End;Begin {Main program} ……… proc1; proc2; proc3; ………End. {End of program}همانطور كه ملاحظه ميكنيد با اعلان روال proc3 بصورت forward، بقيه روالها ميتوانند به آن دسترسي پيدا كنند.
اسلاید 351: توابع (Functions) نوع ديگري از برنامههاي فرعي، توابع ميباشند. توابع مانند روالها، پيمانههاي مستقلي هستند. با اين تفاوت كه روالها ميتوانند، تعدادي خروجي داشته باشند، در حالي که توابع فقط يك خروجي دارند. در روالها معمولاً خروجيها توسط پارامتر به برنامه اصلي ارجاع داده ميشود. ولي در توابع اينكار به نحو ديگر انجام ميگيرد.
اسلاید 352: شكل كلي اعلان يك تابع بصورت زير ميباشد: Function Name ( List Of Parameters ) : Function Type ; نوع تابع ليست پارامترها اسم تابع کلمه ذخيره شده
اسلاید 353: تابع فقط ميتواند، يك خروجي داشته باشد. نوع خروجي تابع، همان نوع تابع محسوب ميشود. لذا با توجه به نوع خروجي تابع، نوع تابع تشخيص داده ميشود. ذكر اين نكته خالي از لطف نيست كه، نوع پارامترهاي صوري توابع معمولاً مقداري هستند چرا كه توابع نوعي برنامههاي فرعي هستند كه فقط يك خروجي برميگردانند. لذا استفاده از پارامترهاي از نوع متغيري پسنديده نميباشد. (اشكال كامپايلري در توربوپاسكال ندارد ولي در پاسكال استاندارد اين كار اشكال كامپايلري دارد.)نکته :مقدار خروجي توابع توسط اسم تابع برگردانده ميشود. توابع مثل روالها بعد از قسمت تعاريف برنامه اصلي ظاهر ميشود.
اسلاید 354: شكل كلي توابع بصورت زير ميباشد: Function Name ( Parameters ) : Type ;Var ………..Begin …………….. …………….. …………….. Name := Resualt Of Function ;End ;
اسلاید 355: توجه به نكات زير در بكارگيري توابع ضروري بنظر ميرسد:تمام پارامترهاي تابع بايد از نوع مقداري باشند.نوع داده نتيجه تابع در انتهاي عنوان تابع و بعد از ليست پارامترهاي صوريقرار ميگيرد.در بدنه تابع، خروجي تابع با نسبت دادن مقدار به نام تابع مشخص ميشود.
اسلاید 356: مثال : برنامهأي بنويسيد كه يك عدد از ورودي دريافت كرده سپس توسط تابعي بنام fact، فاكتوريل عدد را محاسبه در برنامه اصلي چاپ نمايد.Program Example ;Var N: Integer ;Function Fact ( M : Integer ) : longint ;Var P , I : Integer ;Begin P:= 1 ; For i:= 2 To M do P:= P * I ; Fact:= P ;End ;Begin { Main } Write ( Enter Number = ) ; Readln ( N ) ; Writeln ( Factorial is = , Fact ( N ) ) ; {Call Function}End.
اسلاید 357: ناحيه دادهها بعد از فراخواني بشكل زير ميباشد: پارامترهاي واقعيN نتيجه تابعپارامترهاي صوريMمتغيرهاي محليPIنتيجه تابع?? ناحيه داده هاي Fact ناحيه داده هاي اصلي
اسلاید 358: توابع بازگشتي (Recursion Functions) در پاسكال يك تابع يا روال ميتواند، خودش را فراخواني نمايد. پيمانهاي كه خودش را فراخواني ميكند يك پيمانه بازگشتي نام دارد. اين نوع توابع در بدنه خود، خودشان را فراخواني ميكنند. اين فراخواني تا برقراري يك شرط خاص كه غالباً به يك عدد ثابت ختم ميشود، ادامه پيدا ميكند. سپس مقدار تابع از پايين به بالا محاسبه ميشود و در نهايت نتيجه تابع حاصل ميشود.
اسلاید 359: هنگامي كه تابع بازگشتي به خود مراجعه ميكند، مقادير فعلي متغيرهاي خود را در محلي از حافظه بنام پشته (stack) قرار ميدهد، اگر بازگشت به تابع بازگشتي مجدداً صورت گيرد، مقادير فعلي متغيرها مجدداً بدنبال مقادير قبلي و اصطلاحاً در پشت مقادير اوليه قرار ميگيرند. هنگامي كه شرط پاياني در تابع بازگشتي رخ مي دهد، در اولين بازگشت مقاديري را كه هنگام مراجعه به خود، در پشته نگهداري كرده، مجدداً در دسترس قرار ميدهد و بهمين ترتيب در بازگشتهاي بعدي اين عمل تكرار ميشود تا مقدار تابع محاسبه شود.
اسلاید 360: شكل زير نحوه قرار گفتن مراجعههاي يك تابع بازگشتي به پشته را نمايش ميدهد.مقادير متغيرها درآخرين بازگشت به تابع.....مقادير متغيرها در سومين بازگشت به تابعمقادير متغيرها در دومين بازگشت به تابعمقادير متغيرها در اولين بازگشت به تابعشرط پاياني
اسلاید 361: ترتيب دسترسي به مقادير هنگام بازگشت از تابع بازگشتي از بالا به پايين ميباشد و ميتوان آنرا بصورت زير نمايش داد:مقادير متغيرها درآخرين بازگشت به تابع.....مقادير متغيرها در سومين بازگشت به تابعمقادير متغيرها در دومين بازگشت به تابعمقادير متغيرها در اولين بازگشت به تابع
اسلاید 362: مثال : برنامهأي بنويسيد كه با استفاده از توابع بازگشتي فاكتوريل عدد صحيح N را محاسبه نمايد.Program Example ;Var N : integer ;Function Fact ( N : integer ) : Longint ;Begin If N = 1 Then Fact:= 1 Else Fact:= N * Fact ( N – 1 ) ;End ; Begin Writeln ( Enter Number ) ; Writeln ( Factorial is = , Fact ( N ) ); {Call Function}. End
اسلاید 363: Fact := 12 * Fact ( 1 )3 * Fact ( 2 )4 * Fact ( 3 )5 * Fact ( 4 )N = 1 N = 5 در برنامه بالا ترتيب قرار گرفتن مقادير در پشته بصورت زير ميباشد:
اسلاید 364: مثال : تابعي براي محاسبه بزرگترين مقسوم عليه مشترك دو عدد صحيح N , M بنويسيد. Function GCD ( N , M: integer ) : Integer ;Begin If ( N <= M ) and ( M Mod N = 0 ) Then GCD:= N Else GCD:= GCD ( M ,N mod M ) ;End ;
اسلاید 365: مقايسه توابع و روالها توابع و روالها هر دو برنامههاي فرعي هستند، كه بطور مستقل وظايفي را بر عهده دارند. ولي در اين ميان از بعضي جنبهها متفاوت ميباشند كه عبارتند از: 1. نحوه فراخواني آنها با هم متفاوت است. روالها از طريق عبارات روال فراخوانده ميشوند، درصورتي كه فراخواني تابع توسط عبارات مقايسهأي و يا تخصيص نتيجه به يك متغير صورت ميگيرد.2. هنگام اعلان يك تابع، نوع تابع يا نوع نتيجه حاصل از تابع بايد ذكر شود، در صورتي كه روالها نيازي به اين كار ندارند.3. توابع فقط يك خروجي برميگردانند، ولي روالها ميتوانند، چندين خروجيبرگردانند. درضمن نتيجه توابع توسط اسم تابع فرستاده ميشود ولي روالها از طريق پارامترها، نتايج را برميگردانند.
اسلاید 366: طريقه ارسال آرايهها به توابع و روالها آرايهها خود مجموعهأي از دادهها ميباشند، لذا براي ارسال آنها نميتوانيم از روش معمولي ارسال پارامترها استفاده كنيم. و بطور مستقيم نميتوان آنها را به برنامههاي فرعي انتقال داد. براي ارسال آرايهها به عنوان پارامتر به برنامههاي فرعي از دستور Type استفاده ميكنند. دستور Type قبل از تعاريف برنامه اصلي بكار ميرود و توسط اين دستور در واقع يك نوع سادهسازي در تعاريف فراهم ميشود. و با اين سادهسازي ميتوان دادههاي ساخت يافته را به برنامههاي فرعي منتقل كرد.
اسلاید 367: فرم كلي دستور Type در بخش تعاريف بصورت زير است: تعريف داده ساخت يافته = شناسه Type براي مثال يك ارايه از نوع صحيح را تعريف ميكنيم:Type No = array [1…100] of integer ; در اينصورت تعريف آرايه به، No نسبت داده ميشود. اگر بخواهيم متغيري از نوع آرايه بالا تعريف كنيم، آنرا از نوع No تعريف ميكنيم:Var Number: No ;
اسلاید 368: مثال : برنامهاي بنويسيد كه يك آرايه حداكثر 100 عنصري را از ورودي دريافت كرده، سپس عدد را از ورودي خوانده، توسط تابعي بنام Search محل وقوع عدد در آرايه را نمايش دهد.Program Example ;Type a = array [1.. 100] of integer ;Var B: a ; N : Word ;Function Search (b:a; N: Word ; x: integer ) : Word ;Var I , Index: Word ; Flag: Boolean ; { local variable } Begin Index:= 0 ; Flag:= TRUE ;
اسلاید 369: While ( I <= N ) And ( flag ) do Begin If b[ I ] = x Then Begin Index:= I ; Flag:= FALSE ; End ; Inc ( I ) ; End ; Search:= Index ; End ; {*********************************************}
اسلاید 370: Begin { Main } Writeln ( Enter Number ) ; Readln ( N ) ; For I:= 1 To N Do Readln ( b[ I ] ) ; Writeln ( Enter Number ) ; Readln ( x ) ; If Search ( b , N , x ) = 0 Then Writeln ( Not Found ) ; Else Writeln ( Search( b , N , x ) ) ;End. { End Of Program }
اسلاید 371: تمرينات روال Down را در نظر بگيريد:Procedure Down ( N: Integer ) ;Begin While N > 0 do Begin Write ( N: 3 ) ; Dec ( N ) ; End ;End ;الف) وقتي روال بصورت down (5) فراخواني شود، چه چيزي چاپ ميشود. ب) مقدار پارامتر واقعي N بعد از اجراي روال چيست؟
اسلاید 372: تابع بازگشتي زير را در نظر بگيريد: Function MyStery ( M , N: Integer ) : integer ;Begin If N = 1 Then MyStery:= 1 Else MyStery:= M * MyStery ( M , N – 1 ) ;End ; { End Of Function }الف) تابع بازگشتي بالا را به ازاء مقادير N=4 , M=5 فراخواني كنيد.ب) تابع بازگشتي بالا را به ازاء مقادير N=5 , M=3 فراخواني كنيد.
اسلاید 373: تمرينات برنامهنويسي برنامهاي بنويسيد كه اطلاعات حداكثر 100 دانشجو كه عبارتند از: Name اسم Family فاميلي St_No شماره دانشجوئيرا از ورودي دريافت كرده سپس:الف) توسط روالي بنام sort اطلاعات را برحسب شماره دانشجوئي مرتب كند.ب) توسط تابعي بنام search شماره دانشجوئي فردي را از ورودي دريافت نمايد، در صورتي كه شخص موردنظر در ليست باشد، ساير اطلاعات آنرا نمايش دهد.
اسلاید 374: آرايهأي از نوع صحيح با حداكثر 100 عنصر را در نظر بگيريد. برنامهأي بنويسيد كه ابتدا آرايه را از ورودي دريافت كرده سپس با استفاده از يك تابع بازگشتي بيشترين مقدار آرايه را محاسبه نمايد. دو آرايه مرتب حداكثر100 عنصري كه شامل اسامي افراد ميباشد را درنظر بگيريد. برنامهاي بنويسيد كه نخست دو آرايه را از ورودي دريافت نموده سپس توسط روالي بنام merge اين دو آرايه در هم ادغام نموده و در آرايه سومي قرار دهد.
اسلاید 375: فصل 12مجموعهها و دادههاي شمارشيهدفهاي كلي مفهوم مجموعه و دادههاي شمارشي در زبان پاسكال مجموعه و دادههاي شمارشي به عنوان متغير استفاده از مجموعهها و دادههاي شمارشي در برنامه
اسلاید 376: ÷ هدفهاي رفتاري مفهوم مجموعه و دادههاي شمارشي را درك كند. بتواند در صورت لزوم از مجموعه و دادههاي شمارشي استفاده كند.دانشجو پس از مطالعه اين فصل بايد بتواند:
اسلاید 377: تعداد محدودي از دادهها كه از نظر نوع يكسان هستند، در غالب مجموعه و يا گونههاي شمارشي نگهداري ميشوند كه مفهومي شبيه در رياضيات دارند. براي استفاده در مواردي خاص نظير روزهاي هفته و يا نوع ماشينها و... كه ترتيبي هستند و يا يك مجموعه از دادههاي پشت سر هم ميباشند، استفاده از اين ساختارها كار را بسيار راحت ميكند. هر چند وجود آنها به عنوان ساختارهاي دادهاي، الزامينيست. بهرحال به عنوان ابزارهايي از زبان پاسكال هستند كه در مواقعي، ضروري بنظر ميرسند و مسئله را به صورتي قابلفهم و راحت حل ميكند.مقدمه
اسلاید 378: مجموعهها (Sets) در زبان پاسكال مجموعه، مفهومي شبيه به مفهوم مجموعه در رياضيات جديد دارد. متغيري است كه شامل ليستي از اعداد صحيح، كاراكتر، بولين و يا از نوع شمارشي ميباشد كه داراي تعداد عناصر محدود به حداكثر 256 تا ميباشد. از اين جهت بسيار شبيه به يك آرايه در زبان پاسكال است كه شامل دادههايي از يك نوع ميباشد، ولي آرايه داراي عناصر محدودي نيست و در ضمن مانند آرايه تعريف نميشود.
اسلاید 379: تعريف مجموعهبراي تعريف يك مجموعه از كلمات كليدي set of بصورت زیر استفاده ميكنيم: TypeName= Set of Type Of Set; Type Digit_type = 0..9; Digit = Set of Digit_type مثلا :
اسلاید 380: Varch: set of char; #0..#255bool: set of boolean; false..truenum: set of byte; 0..255x: set of 100..200;y: set of a..z;z: set of 0..9;مثال :
اسلاید 381: عمليات روي مجموعهها در رياضيات عمل عضويت وجود دارد كه به اين معني است كه متغيري عضو مجموعه ميباشد يا خير. اين عمل در زبان پاسكال با كلمه كليدي in صورت ميگيرد. اگر عضويت صحيح باشد جواب True وگرنه False ميباشد. همچنين دو مجموعه را ميتوان با علامات شرطي =، <>، <= و >= مقايسه كرد كه همگي داراي خروجي درست يا غلط ميباشند. وليعلامات شرطي < و > در مورد مجموعهها كاربردي ندارد.
اسلاید 382: Vara: set of byte;Begina:= [1..3,4];if 3 in a then write(3 is in set a) چاپ ميشودelse write(3 is not in set a); write(3 in a); True write(8 in a); Falsewrite([1,2,3,4,] = a); Truewrite([1,2,3,4] = [2,2,1,1,1,3,4,4]); Truewrite([1,2] = [1,2,3]); Falsewrite([1,2] <= [1,2,3]); Truewrite([] >= [1]); FalseEnd.مثال :
اسلاید 383: در رياضيات ميتوانيم مجموعهها را با هم اجتماع، اشتراك و تفاضل كنيم كه اين عمليات در پاسكال با عملگرهاي +، * و - به ترتيب ميباشد. اجتماع دو مجموعه تركيبي از همه عضوهاي آنها است و اشتراك يعني عضوهايي كه در هر دو مجموعه مشترك است و تفاضل يعني اعضايي كه در مجموعه اول ميباشد و در مجموعه دوم وجود ندارد. عملگرها روي مجموعهها
اسلاید 384: مثال :Var a: set of byte; b: set of 0..10; c, d, e: set of byte;Begin a:=[0,1,2,3]; b:=[2,3,4,5]; c:= a+b;c=[0,1,2,3,4,5]=[0..5] d:= a*b;d=[2,3] e:= a-b;e=[0,1]End.
اسلاید 385: در استفاده از مجموعه ها به نکات زیر توجه کنید :1. آرگومان ورودي روالها ميتواند مجموعه باشد كه قبلاً در تايپ تعريف شده باشد، نه اينكه مستقيم در روال به عنوان آرگومان بيايد. ولي خروجي يك تابع نميتواند از نوع مجموعه باشد.2. براي نوشتن يا خواندن مجموعهها بايد عضو به عضو عمليات صورتبگيرد و مستقيماً توابع Write، Read روي آنها كار نميكنند.
اسلاید 386: مثال : برنامهاي بنويسيد كه تعداد محدودي عدد مختوم به 1- را از ورودي بخواند و در يك مجموعه از اعداد صحيح قرار بدهد. سپس اعضاي اين مجموعه را با توجه به مجموعه ساخته شده در خروجي چاپ كند:Program test ;Var num , temp : set of byte; I , c : integer ;Begin Writln (Enter numbers: ); Readln( I ) ; Num := [ ] ; c := 0 ;
اسلاید 387: while ( i > -1) do begin c := c + 1 ; temp := [ I ] ; num := num + temp ; Readln( I ) ; end; for I := 0 to 255 do if ( i in num ) then write( i:5 ) ;End.{ End Of Program }
اسلاید 388: دادههاي شمارشي (Enumeration) دادههاي شمارشي، يك مجموعه مرتب از اعداد است كه در برنامه، هر عدد داراي نام بخصوصي است. اين نامها در داخل دو پرانتز باز و بسته قرار ميگيرند و بترتيب از صفر مقدار ميگيرند مگر اينكه برنامهنويس به آنها مقدار مخصوصي بدهد.
اسلاید 389: به مثال زير توجه كنيد : Type Cars_type = (Peykan, Pride, Pegout, PK);Var Cars: cars_type;حال در برنامه cars ميتواند مقادير داخل دادههاي شمارشي را بگيرد:cars:= Pride;cars:= PK;
اسلاید 390: Type Days_type = ( sat, sun, mon, tue, wed, thu, fri );Var Day: Days_type;Begin Day:= Mon; i:= ord (sat) + ord (day) + (succ(sat)); j:= ord ( pred (sun) + ord (pred (fri)); writeln(i:5, j:5);End.به مثال زير توجه كنيد : خروجی : i = 3 j = 5
اسلاید 391: متغير داده شمارشي شبيه مجموعهها حداكثر داراي 256 عضو ميتواند باشد كه از صفر تا 255 شمارهگذاري ميشود و لذا يك بايت حافظه را اشغال ميكند.نکته :
اسلاید 392: عمليات روي دادههاي شمارشيدادههاي شمارشي همانند هر نوع تايپي ميتوانند در type برنامه تعريف شود و به عنوان آرگومانهاي روالها و يا خروجي توابع ميتواند درنظر گرفته شود ولي حتماً بايد در type تعريف شده باشد و مستقيماً نميتوان بكار برد. اين عمل مشابه مجموعهها و آرايهها نيز ميباشند، لذا ابتدا در type تعريف ميشود، سپس به عنوان ورودي و يا خروجي روالها استفاده ميشود وگرنه خطاي كامپايلري پيش خواهد آمد. همچنين ميتوان در آرايهها از دادهها شمارشي استفاده كرد.
اسلاید 393: مثال : مشابه مجموعهها نميتوان دادههاي شمارشي را مستقيماً Read يا Write كرد. برنامهاي بنويسيد كه اعداد صفر تا شش را به مراتب دريافت كرده و به كمك دادههاي شمارشي روزهاي متناظر با آنها را از شنبه تا جمعه را حساب كند.Program test:Type days_type = ( sat,sun,mon,tue,wed,thu,fri ) ;Var day: days_type; i: byte;Begin Write(Enter your days number: ); Readln(i); While (i>=0) and (i<=6) do begin Case I Of
اسلاید 394: 0: day:= sat; 1: day:= sun; 2: day:= mon; 3: day:= tue; 4: day:= wed; 5: day:= thu; 6:day:= fri; end; Case day Of sat: writeln (your day is sat); sun: writeln (your day is sun); : end; Readln(i);End; {while} End.
اسلاید 395: تمرينات اگر A=[1,3,5,7] و B=[2,4,6] و C=[1,2,3] باشد عبارات زير راارزيابی کنيد.الف- A + (B –C) ب- A + (B*C)ج- A + B + Cد – 2 in A
اسلاید 396: برنامهاي بنويسيد تا مجموعه اي از كاراكترهاي كوچك را گرفته و به يك مجموعه از كاراكترهاي حروف بزرگ متناظر با آن تبديل كند. به كمك دادههاي شمارشي، برنامه اي بنويسيد كه نام دانشجويان يك كلاس را در برگيرد و هر دانشجو نيز يك شماره داشته باشد. سپس با دريافت نام او شماره او در نمايشگر چاپ شود.
اسلاید 397: فصل 13(Records) ركوردها هدفهاي كلي مفهوم ركورد و اجزاي آن انواع ركوردها و استفاده از آن در برنامه معرفي مزاياي ركوردها در برنامه
اسلاید 398: ÷ هدفهاي رفتاري مواقع لزوم ركورد را تشخيص دهد. از ركوردها در برنامهاش استفاده كند. برنامههاي بزرگ و با دادههاي زياد بنويسد.دانشجو پس از مطالعه اين فصل بايد بتواند:
اسلاید 399: مقدمه نوع داده ساختيافتهاي كه در اينجا مطرح ميشود، ركورد نام دارد كه جهت نگهداري دادههاي مختلف نظير نام، نام خانوادگي، سن و آدرس براي يك دانشجو بكار ميرود. ركوردها برخلاف آرايهها كه داراي عناصر از يك جنس و نوع هستند، داراي عناصر از انواع مختلف ميباشند. اطلاعات ازنوع مختلف را نميتوان در آرايه نگهداري كرد چرا كه داراي جنس مشابه نيستند و لذا از ساختاري به نام ركورد استفاده ميشود.
اسلاید 400: تعريف ركوردها نوع داده ساختيافته ای که از یک سری داده ها یا اطلاعات مرتبط به هم تشکیل می شود.هر کدام از اطلاعات را یک فیلد می نامند .بطور كلي تعريف نوع ركورد در زير آمده است:TypeName = RecordField1-list : type1;Field2-list : type2;....Fieldn-list : typen; End;
اسلاید 401: براي ساختن ركورد، از كلمه كليدي Record استفاده ميشود كه مطابق زيرميباشد:Type Student = Record Name: String [10]; Family: String [15]; Age: integer; Address: String; End;در اين تعريف Student از نوع Record است. حال ميتوان در var برنامه تعريف كرد:VarS: Student;
اسلاید 402: دسترسي به فيلدهاي ركوردبراي دسترسي به فيلدهاي ركورد ازعلامت . استفاده ميشود. يعني بصورتزير: نام فيلد . نام متغير ركورد مثال: برنامهاي بنويسيد كه ركوردي از نوع اعداد ايجاد كرده و مقادير آنرا مقدارهي كند.
اسلاید 403: TypeNumbers = record a, b, c = integer; x, y, z = Real;end;Var Num = Numbers;beginNum. a: = 2;Num. b: = 3;Num. x: = 2.5;Num. y: = 3.5;Num. z: = 10;Write (Num.a + Num.b + Num.x + Num.y + Num.z);End.
اسلاید 404: مثال : برنامهاي بنويسيد كه ركورد يك دانشجو را داشته باشد و با توجه به جنس او كلمه آقا و يا خانم را به همراه نام و نام خانوادگياش را چاپ كند.Type Student = recordId: integer;Name: string[10];Family: string[15];Sex: char;Age: integer; End;Var Stu: student;
اسلاید 405: Begin Stu.id:= 80132; Stu.name:=Ali; Stu.family:=Ahmadi; Stu.sex:=M; Stu.sge:=18; Case sex of M: write(Mr.); F: write(Mrs.); end; write(stu.name, , stu.family);End.
اسلاید 406: بدست آوردن حجم يك ركوردبراي بدست آوردن فضاي اشغال شده توسط ركورد ابتدا بايد فضاي اشغال شده توسط تماميفيلدها را بدست آورده و سپس باهم جمع كنيم. مثال زير را درنظر بگيريد:
اسلاید 407: Type List1 = Array [1… 5] of integer;List2 = Array [1… 5] of char;Rectype = RecordA, B: Real; 6*2C, D: String [10]; 10+1F: Array [1… 10] of Boolean; 1*10G: list1; 2*5End;Varx: Rectype; 43=10+10+11+12 بايت فضا اشغال ميشود.
اسلاید 408: ركوردهاي تودرتو فيلدهاي يك ركورد ميتوانند از هر نوعي باشد، از جمله ميتوانند از نوع ركورد ديگري باشند. در اينجا نيز مشابه قبل دسترسي به همان صورت ميباشد فقط به تعداد ركوردهاي تودرتو، . پيش ميآيد. به مثال زيرتوجه كنيد:TypeRec = record a, b: integer; c: char; x: Record p: integer; q: integer; End; End;
اسلاید 409: Var r: Rec;دراينجا يك ركورد تودرتو به نام Rec تعريف شده است كه متغير r از آن نوع تعريف شده است. سپس براي دسترسي به فيلدهاي a , b ,c ميتوان به صورت زير عمل كرد:r.ar.bولي براي دسترسي به فيلدهاي p ,q چون متعلق به ركورد x نيز هستند داريم:r.x.pr.x.q
اسلاید 410: آرايهاي از ركوردها هنگاميكه ما تعدادي داده مشابه داريم ولي در هريك، دادههاي مختلفي وجود دارد ميتوانيم يك ركورد تعريف كرده، سپس آرايهاي از آن تعريف كنيم. Type Student = recordName: string[10];Id: integer;Age: integer; End; Arr_stu: array[1..10] of student;Var S: Arr_stu;
اسلاید 411: در بالا ابتدا يك ركورد دانشجو تعريف شده است، سپس به تعداد 10 نفر دانشجو تحت آرايه Arr_stu شكل گرفته است و سرانجام متغيري به نام S از نوع آن تعريف شده است. مشابه ساختار آرايه، چيزي عوض نشده است و فقط هر عنصر آرايه، يک ركورد ميباشد كه داراي سه فيلد مطابق جدول فوق ميباشد. براي دسترسي به آرایه فوق داريم:S[1].name S[1].idS[1].ageS[2].nameS[2].id......
اسلاید 412: ارسال ركورد به زيربرنامهها ركوردها را ميتوان مشابه انواع تعاريف ساده ديگر به صورت پارامترهاي متغير و مقدار به زيربرنامه ارسال كرد. ولي نوع برگشتي توابع نميتواند از نوع ركورد باشد، يعني حتماً بايد از نوع ساده نظير integer، char و... باشد و از انواع تركيبي نظير ركورد، آرايه، مجموعه و فايل نميتواند باشد.اگر بخواهيم ركوردي را بصورت پارامتر به زيربرنامه ارسال كنيم، ابتدا بايد آنرا در type تعريف كرده و سپس ارسال شود وگرنه كامپايلر خطا صادر ميكند.
اسلاید 413: مثال : ميخواهيم برنامهاي بنويسيم كه ركورد stu را براي 30 دانشجو ايجاد كرده، به كمك زيربرنامه مقداردهي شده و چاپ شوند.Program test;Const no = 30;TypeStu-rec = RecordName: string [10];ID: integer;Age: record Day: integer; Month: integer; Year: integer;End;End;Stu_arr=array[1..no] of stu_rec;
اسلاید 414: VarStu: stu_rec;Procedure ReadStu(Var S: Stu_rec);Vari: integer;Begin for i:= 1 to no do Readln(S[i].name, S[i].id, S[i].age.day, S[i].age.month, S[i].age.year);End;
اسلاید 415: Procedure WriteStu(S: Stu_rec);Vari: integer;Begin for i:= 1 to no do Writeln(S[i].name, , S[i].id, , S[i].age.day, , S[i].age.month, , S[i].age.year);End;Begin ReadStu(Stu); WriteStu(Stu);End.
اسلاید 416: تمرينات براي گونههاي حيوانات يك پارك نظير پرندگان وحشي ركوردي شامل نام، دسته، محيط زندگي، سن بسازيد. در نظر بگيريد كه در پارك 100 گونه از يك پرنده وحشي وجود دارد (راهنمايي: آرايهاي از ركورد با فيلدهاي گفته شده بسازيد). برنامهاي بنويسيد كه براي نگهداري تاريخ به صورت روز، ماه و سال براي 100 سال بكار رود. در واقع به صورت تقويم باشد و جملهاي در مورد آن تاريخ را نگهداري كنيد؟ (راهنمايي: آرايهاي 366 تايي از روز بهمراه آرايهاي از 12 ماه و يك سال و يك رشته را به صورت يك ركورد در نظر گرفته سپس براي 100 سال بصورت يك آرايه صدتايي در نظر بگيريد.)
اسلاید 417: فصل 14(Files) فــايـلهاهدفهاي كلي مفهوم فايل و انواع آن موارد استفاده از فايلها
اسلاید 418: ÷ هدفهاي رفتاري در برنامهاش از فايلها استفاده كند.. براي برنامههاي با دادههاي زياد از فايل استفاده كند.. با فايلهای دادهاي و بايزي برنامهنويسي كند.دانشجو پس از مطالعه اين فصل بايد بتواند:
اسلاید 419: مقدمهبراي ذخيره دائمي دادهها از ساختاري به نام فايل (File) استفاده ميكنيم. تاكنون همه عمليات لازم در حافظه اصلي انجام ميگرفت كه گذرا و فقط به زمان اجراي برنامه و روشن بودن كامپيوتر بستگي داشت. ولي در فايلها چنين نيست، بلكه دادهها در فايلهايي قرار دارند كه حتي بعد از خاموش كردن كامپيوتر، بعدها قابل دسترسي است.
اسلاید 420: فايلهاي متني (Text) يك فايل متني از تعداد كاراكتر تشكيل شده است كه با يك اسم در روي ديسك ذخيره شده است. چون فايل از نوع متني است ميتوانيد دادههاي داخل آنرا مشاهده كنيد.ساختار دادهها در يك فايل متني بدين صورت است كه تعدادي خط وجود دارد كه به علامت EOLN ختم ميشوند و در انتهاي فايل نيز علامت EOF قرار دارد. طول خطوط نامشخص است و اندازه فايل ممكن است بسيار بزرگ يا كوچك و يا تهي باشد.
اسلاید 421: طريقه ایجاد يك فايل متنيتعریف یک متغیر فایلی نسبت دادن اسم فایل به متغیر فایلی ایجاد فایل با دستور Rewrite
اسلاید 422: تعریف یک متغیر فایلیName : Text;نسبت دادن اسم فایل به متغیر فایلیAssign(FileVar , ‘NameFile’ )ایجاد فایل با دستور RewriteRewrite( FileVar )
اسلاید 423: مثال : برنامهاي بنويسيد كه از ورودي 10 عدد دريافت كند و آنها را به ترتيب هر كدام دريك خط ازيك فايل خروجي بريزد و در انتها تعداد و مجموع آنها را بنويسد.Var f: Text;A: Array [ 1.. 10] of integer;Sum, i: integer;Begin Sum: = 0;Writeln ( Enter 10 numbers: ); For i: = 1 to 10 do begin Read (A [i]); Sum: = sum + A[i]; end; Assign (f, out.dat); Rewrite (f);
اسلاید 424: For i: = 1 to 10 do Writeln (f, A[i]); Writeln (f, Sum); Close (f);End.بعد از نوشته شدن اطلاعات در فایل ، فایل باید بسته شود برای اینکار از روال زیر استفاده می شود :Close(FileName)
اسلاید 425: طريقه خواندن اطلاعات از يك فايل متنيتعریف یک متغیر فایلی نسبت دادن اسم فایل به متغیر فایلی باز کردن فایل برای خواندن با دستورReset
اسلاید 426: باز کردن فایل برای خواندن با دستورReset ( FileName )دستور Read وReadln برای خواندن اطلاعات از فایل بکار می روند .Readln بعد از خواندن دادههاي مورد نظر به سطر بعد ميرود. اين عمل براي Writeln نيز چنين ميباشد. ولي قبل از استفاده از اين دستورات بايد فايل متني براي خواندن يا نوشتن باز شود. دستور Reset فايل متني را براي خواندن باز ميكند و مكان نما را ابتداي فايل ميبرد. دستور Rewrite فايل متني را براي نوشتن در آن باز كرده، و مكان نما را به ابتداي آن ميبرد.
اسلاید 427: حال بافرض موجود بودن فایل متني test.dat ميخواهيم اعداد داخل فايل را كه پنج تا هستند را از فایل خوانده باهم جمع كنیم :Program usefile ;Varf: Text;str1, str2: string; a, b, c, d, e: integer;beginAssign (f, Test. dat );Reset (f);Readln (f, str1);Readln (f, a, b, c);Readln (f, d, e, str2);Write (str2, : , a + b + c + d + e );Close (f);End.
اسلاید 428: مثال : برنامهاي بنويسيد كه يك فايل متني شامل چند جمله را از ورودي دريافت كرده و يك كپي از فايل درخروجي بسازد.var f1,f2: Text; str1,str2 : string ; ch : char ;begin write(Enter Input file: ); readln(str1); write(Enter output (copy) file: ); readln(str2); assign(f1,strl); reset(f1); assign(f2,str2); rewrite(f2);
اسلاید 429: در اين برنامه ابتدا دو فايل به نامهايشان نسبت داده ميشوند و ترتيب براي خواندن و نوشتن باز ميشوند. سپس توسط eof شرط خاتمه فايل ورودي يعني f1 بررسي ميشوند و در يك حلقه تو در تو while شرط خاتمه خطوط نيز توسطeoln بررسي شده و كاراكترها از فايل ورودي خوانده شده و در فايل خروجي نوشته ميشوند.
اسلاید 430: while not eof ( f1 ) do begin while not eoln( f1 ) do begin read(f1,ch); write(f2,ch); end; readln(f1); writeln(f2); end; Close(f1); Close(f2);End.
اسلاید 431: فايلهاي دودويي و نوعدار(Binary & Typed ) اين نوع فايلها در زبان پاسكال از تايپهاي مختلف record ,array ,read ,integer ,char و … تشكيل شده است كه نياز به پردازش متنوعشبيه مرتبسازي، جستجو، حذف و… دارند. اين فايلها پس از ايجاد توسط برنامه، قابل رؤيت توسط ويراشگرها نيستند، بلكه به صورت كدهاي اسكي ميباشند يعني دودويي ميباشند. نحوه دسترسي به اطلاعات آنها نيز به صورت تصادفي (Random) است.
اسلاید 432: طريقه ایجاد يك فايل نوع دارتعریف یک متغیر فایلی نسبت دادن اسم فایل به متغیر فایلی ایجاد فایل با دستور Rewrite
اسلاید 433: تعریف یک متغیر فایلیName : File Of FileType ;نسبت دادن اسم فایل به متغیر فایلیAssign(FileVar , ‘NameFile’ )ایجاد فایل با دستور RewriteRewrite( FileVar )
اسلاید 434: نحوه تعريف يك فايل دودويي نوعدار از انواع مختلف در زير آورده شده است:Const n=100;Type Student = Record Name: string[10]; Family: String[15]; Age: integer; ID: integer; end;Sarray = Array [1..n] of student;
اسلاید 435: Varفايل دودويي از نوع كاراكتر Bf1: file of char;فايل دودويي از نوع صحيح Bf2: file of integer;فايل دودويي از نوع ركورد دانشجو Bf3: file of student;فايل دودويي از مجموعهA تا Z Bf6: file of set of A..Z; مثال :
اسلاید 436: مثال : برنامهاي بنويسيد كه تعداد رشته (حداكثر 10 تايي) از ورودي خوانده و در يك فايل دودويي بنويسيد.Const n= 10;Var Bf: file of strin[10]; Str: string [10]; i: integer;Begin Assign (Bf,out.dat); Rewrite (Bf); For i:=1 to n do Begin Readln (str); Write (Bf,str); End; Close (Bf);End.
اسلاید 437: در جدول صفحه بعد تمام روالهاي كتابخانهاي پاسكال جهت كار با فايلها آورده شده است كه به همراه توضيحات لازمه جهت كار با آنها ميباشد. همچنين براي هر تابع و رويه محل مورد استفاده آن در ستونی مشخص شده است .
اسلاید 440: مثال های حل شده مثال : برنامهاي بنويسيد كه تعداد خطوط يك فايل متني را بدست آورد.Var F: text ; ch : char ; str: string[20]; count: integer;Begin Write (Enter the file name: ); Readln(str); Assign(f,str); Reset(f);
اسلاید 441: count:=0; While not eof(f) do begin While not eoln(f) do Read(f,ch); Readln(f); count:=count+1; end; Write(the number of lines in file is: ,count);End.
اسلاید 442: مثال : ركوردي از كتابها در نظر گرفته، تعداد10 كتاب را در يك فايل نوع دار ذخيره كنيد.Const n = 10;Type Booktype = Record name: string[20]; ID: integer; end;Var Bf: file of Booktype; I , ID : integer; name: string[20]; Book: Book type;
اسلاید 443: Begin Assign (Bf,book.dat); Rewrite (Bf); For I := 1 to n do begin Write (Enter the name & ID of book: ); Readln (name, ID); Book.name:= name; Book.ID:= ID; Write (Bf, Book); End; Close (Bf);End.
اسلاید 444: تمرينات برنامهاي بنويسيد كه از يك فايل متني از اعداد حقيقي كه در سطرها و ستونها مختلف قرار دارند، ميانگين دادهها را بدست آورده و در مانيتور چاپ كند.برنامهاي بنويسيد كه در انتهاي يك فايل متني، همان فايل متني را اضافه كند. برنامهاي بنويسيد كه در يك فايل نوع دار از كاراكترها، اطلاعات آماري هر كاراكتر را بدست آورده، يعني تعداد هر كاراكتر را بدست آورد. مثلاً كاراكتر A به تعداد 45 تا و كاراكتر B به تعداد 36 تا و…
اسلاید 445: فصل 15تحليل الگوريتمها هدفهاي كلي مفهوم و تعريف الگوريتم مفهوم كارايي يك الگوريتم مرتبه يك الگوريتم
اسلاید 446: ÷ هدفهاي رفتاري برنامه خود را تحليل زماني نمايد. مرتبه الگوريتم را بدست آورد. الگوريتمهاي بازگشتي را تحليل نمايد.دانشجو پس از مطالعه اين فصل بايد بتواند:
اسلاید 447: مقدمه تحليل يك الگوريتم يعني ارزيابي روشهاي مختلف حل آن مسئله، بررسي و محاسبه بهترين و بدترين حالتها، بصورتي كه با توجه به شرايط بهترين حالت را بتوان انتخاب كرد. الگوريتم در واقع تعداد محدودي از دستورالعملها می باشد كه بترتيب اجرا ميشوند و هدف خاصي را دنبال ميكنند
اسلاید 448: تعريف مرتبه يا پيچيدگي الگوريتم (O بزرگ) براي بدست آوردن بدترين حالت اجراي يك الگوريتم يا مرتبه پيچيدگي الگوريتم از O بزرگ استفاده ميكنيم و بنا به تعريف عبارتست از f(n)=O(g(n)) و ميخوانيم f(x) از مرتبه g(x) ميباشد، اگر و تنها
اسلاید 449: رمثال : 1+n2=f(n) ميتوان با در نظرگرفتن g(n)=n و3=c رابطه زیر حاصل می شود :1n n>=3 <= cg(n)=1n+2f(n)=لذا ميتوان گفت، پيچيدگي زماني f(n) از مرتبه O(n) ميباشد.
اسلاید 450: بدست آوردن مرتبه الگوريتمها براي بدست آوردن مرتبه اجراي الگوريتمها بايد به دقت بررسي شود و تعداد تكرار آن الگوريتم بدست آورده شود. يعني در واقع تعداد تكرارها بدست آورده شود و سپس با هم جمع شده و مطابق مثالهاي قبلي به پيچيدگي زمان واقعي رسيد. براي اين منظور از الگوريتمهاي ساده شروع كرده و به پيچيده ميرسيم.
اسلاید 451: فرض كنيد الگوريتمي داراي حلقههاي ساده به شكل زير باشد:x:= 0;For I :=1 to n do x:=x+1; كه در آن n تعداد ورودي ميباشد. يعني حلقه for بستگي به پارامتر n دارد. همان طور كه از تعريف حلقه for برميآيد تعداد 1+1-n تكرار يعني n تكرار وجود دارد و لذا قطعه برنامه فوق از مرتبهO(n) ميباشد.
اسلاید 452: مثال : مرتبه تابع زير را بدست آوريد:Function fact ( n : integer ) : integer ;var f,i: integer;begin f:=1; for I := 1 to n do f:=f*i; fact:=f;end;
اسلاید 453: تابع فوق فاكتوريل عدد n را بر ميگرداند. همانطور كه ميبينيد تابع شامل يك حلقه for ساده بوده كه از يك تا n متغير بوده و لذا n بار تكرار ميشود. 2 جمله ساده نيز وجود دارد که زمان های ثابتی دارند. بنابراین مرتبه تابع بالا برابر است با : O(n)
اسلاید 454: تمرينات پيچيدگي زماني توابع زير را بدست آوريد:
اسلاید 455: پيچيدگي زماني تابع زير را بدست آوريد:Function test( n : integer ) : integer ;var i,x: integer;Begin x:=0; for i:=1 to n do x:=x+1; for i:=1 to n do for j:=1 to n do x:=x+1; test:=x;End.
اسلاید 456: پایان
خرید پاورپوینت توسط کلیه کارتهای شتاب امکانپذیر است و بلافاصله پس از خرید، لینک دانلود پاورپوینت در اختیار شما قرار خواهد گرفت.
در صورت عدم رضایت سفارش برگشت و وجه به حساب شما برگشت داده خواهد شد.
در صورت نیاز با شماره 09353405883 در واتساپ، ایتا و روبیکا تماس بگیرید.
- پاورپوینتهای مشابه
نقد و بررسی ها
هیچ نظری برای این پاورپوینت نوشته نشده است.