mabaniye_compiuter

در نمایش آنلاین پاورپوینت، ممکن است بعضی علائم، اعداد و حتی فونت‌ها به خوبی نمایش داده نشود. این مشکل در فایل اصلی پاورپوینت وجود ندارد.






  • جزئیات
  • امتیاز و نظرات
  • متن پاورپوینت

امتیاز

درحال ارسال
امتیاز کاربر [0 رای]

نقد و بررسی ها

هیچ نظری برای این پاورپوینت نوشته نشده است.

اولین کسی باشید که نظری می نویسد “مبانی کامپیوتر”

مبانی کامپیوتر

اسلاید 1: مبانی کامپیوتر ارائه دهنده : جعفر تنهامولفین : جعفر تنها – مهدی یوسف خانی1گروه آموزشی مهندسی ایران Iranian Engineering Group WWW.MOHANDE30.COM

اسلاید 2: اهداف كلي این درس الگوریتمی برای حل مسئله ارائه دهداصول و مبانی اولیه نرم افزار و سخت افزار را بشناسد اهداف و مفا هیم زبان های برنامه نویسی را بداندمفاهیم اولیه برنامه نویسی ساخت یافته را بداند و اصول لازم را در مرحله اجراء بکار ببرددستورات زبان پاسکال را در برنامه ها بکار ببرداز توابع و روال های استاندارد زبان پاسکال در صورت لوزم استفاده نماید دانشجو پس از مطالعه اين درس بايد بتواند:2گروه آموزشی مهندسی ایران Iranian Engineering Group WWW.MOHANDE30.COM

اسلاید 3: از توابع ، روال ها برای جدا کردن قطعات برنامه استفاده کندفایل ها را به عنوان محلی برای ذخیره داده ها در برنامه استفاده کند با استفاده از قابلیت های زبان پاسکال برنامه ای را برای یک سیستم بنویسد.3گروه آموزشی مهندسی ایران Iranian Engineering Group WWW.MOHANDE30.COM

اسلاید 4: جایگاه این درس در رشته مهندسی کامپیوتراین درس اولین درس دانشگاهی رشته می باشد و نقطه شروعی برای ورود به دنیای جالب برنامه نویسی و علم و فن کامپیوتر هست . بنابراین یاد گیری اصول اولیه برنامه نویسی در این درس از جایگاه ویژه ای برخوردار است.این درس پایه و اساس برنامه نویسی که جزء اصول این رشته می باشد را به فرگیران یاد می دهد .بنابراین یادگیری دقیق این درس به همراه ارائه پروژه های عملی که لازمه این درس می باشد جزء اهم مسائل می باشد .4گروه آموزشی مهندسی ایران Iranian Engineering Group WWW.MOHANDE30.COM

اسلاید 5: طرح درس توصیه می شود این درس در بیست جلسه بصورت ذیل ارائه شود :بخش اول :( در پنج جلسه ) اهداف درس و فصل اول و دوم کتاب درسیجلسه هفتم :فصل چهارم کتاب درسیجلسه ششم :فصل سوم کتاب درسیبخش دوم :5

اسلاید 6: جلسه سیزدهم:فصل نهم کتاب درسیجلسه دوازدهم :فصل هشتم کتاب درسیجلسه دهم و یازدهم :فصل هفتم کتاب درسیجلسه نهم :فصل ششمکتاب درسیجلسه هشتم :فصل پنجم کتاب درسی6

اسلاید 7: جلسه نوزدهم :فصل چهاردهم کتاب درسیجلسه هیجدهم :فصل سیزدهم کتاب درسیجلسه پانزدهم و شانزدهم :فصل یازدهم کتاب درسیجلسه هفدهم :فصل دوازدهم کتاب درسیجلسه چهاردهم :فصل دهم کتاب درسی7

اسلاید 8: جلسه بیستم :فصل پانزدهم کتاب درسی و ارائه پروژه نهائی درس8

اسلاید 9: فصل 1Algorithm الگوریتم هاهدفهاي كليشناخت اجزاء لازم برای حل مسئله شناخت حل مسئله و ارائه الگوریتم بررسی صحت الگوریتم9

اسلاید 10: هدفهاي رفتاري الگوریتمی را برای حل مسئله ارائه دهد. الگوریتم های مختلف برای یک مسئله را مقایسه کند. شرط ها و حلقه ها را در الگوریتم بکار ببرد . دانشجو پس از مطالعه اين فصل بايد بتواند:10

اسلاید 11: مقدمه در زندگي روزمره، انسان با مسائل مختلفي روبروست و براي هر كدام از اين مسائل (حل مشكلات) راه حلي و روشي را بر مي‌گزيند. مسائلی از قبيل راه رفتن، غذا خوردن، خوابيدن و غيره كه بشر تقريباً هر روز آنها را پيش روي خود دارد. همه اين مسائل نياز به روشي براي حل كردن دارند مثلا راه رفتن بايد با ترتيب خاصي و مراحل معيني انجام شود. تا مسئله راه رفتن براي بشر حل شود. اصطلاحاً روش انجام كار يا حل مسئله را الگوريتم آن مسئله مي‌نامند11

اسلاید 12: تعريف الگوريتم الگوريتم مجموعه‌اي از دستورالعمل ها، براي حل مسئله مي‌باشد كه شرايط زير را بايد دارا باشد: دقيق باشد جزئيات كامل حل مسئله را داشته باشد.پايان‌پذير باشد.12

اسلاید 13: مراحل الگوريتم براي حل يك مسئله بايد الگوريتم آن مسئله را مشخص كنيم (يا بيابيم). كه اصطلاحاً طراحي الگوريتم براي آن مسئله ناميده مي‌شود. در طراحي الگوريتم معمولاً سه مرحله زير را از هم جدا مي‌كنند:خواندن داده‌هاانجام محاسباتخروجي‌ها13

اسلاید 14: مثال : الگوريتمي بنويسيد كه دو عدد از ورودي دريافت كرده مجموع دو عدد را محاسبه و چاپ نمايد. خروجي‌ها انجام محاسبات وروديها مجموع دو عدد جمع دو عدد a , b 0ـ شروع 1ـ b ,a را بخوان.2ـ مجموع b , a را محاسبه و در sum قرار بده.3ـ sum را در خروجي چاپ كن 4ـ پايان14

اسلاید 15: خروجي‌ها انجام محاسبات وروديها چاپ مجموع محاسبه مجموع a چاپ ميانگين محاسبه ميانگين b c مثال: الگوريتمي بنويسيد كه سه عدد از ورودي دريافت كرده مجموع و ميانگين سه عدد را محاسبه و چاپ كند.0ـ شروع1ـ سه عدد از ورودي بخوان2ـ مجموع سه عدد را محاسبه و در sum قرار بده.3ـ sum را بر سه تقسيم كرده،در ave قرار بده.4ـ ave , sum را در خروجي چاپ كن.5ـ پايان.15

اسلاید 16: معمولا درك يك الگوريتم با شكل راحتر از نوشتن آن بصورت متن مي‌باشد. لذا الگوريتم را با فلوچارت( flowchart )نمايش مي‌دهند. فلوچارت از شكل‌هاي زير تشكيل مي‌شود.BeginEndخواندن یا Readچاپ کردن writeعلامت‌هاي شروع و پايان: كه معمولا از يك بيضي استفاده مي‌كنند: علامتهاي ورودي و خروجي: كه معمولا از متوازي‌الاضلاع استفاده مي‌شود:16

اسلاید 17: علامتهاي محاسباتي و جايگزيني: براي نمايش دستورات جايگزيني و محاسباتي از مستطيل استفاده مي‌كنند:جایگزین یا محاسباتعلامت شرط: براي نمايش شرط از لوزي استفاده مي‌شود.علامت اتصال: براي اتصال شكل‌هاي مختلف بهم از فلش‌هاي جهت‌دار استفاده مي‌كنند.17

اسلاید 18: BeginRead(a,b,c)Sum a+b+cAve sum/3Write(sum,ave)Endفلوچارت مجموع سه عدد18

اسلاید 19: مثال: فلوچارتی رسم نمائيد كه دو عدد از ورودي دريافت كرده سپس محتويات دو عدد را با هم جابجا ‌نمايد.براي حل اين مسئله b , a را دو متغير كه در آنها دو عدد خوانده شده، قرار مي‌گيرند در نظر مي‌گيريم. سپس با استفاده از يك متغير كمكي محتويات اين دو عدد را جابجا مي‌كنيم : 19

اسلاید 20: 1215temptempab121512abtemp151512abtemp151212abtemp20

اسلاید 21: BeginRead(a,b)temp aa bWrite(a,b)Endb tempفلوچارت مسئله بالا بصورت زير خواهد بود: 21

اسلاید 22: تمرين1ـ فلوچارتي رسم نمائيد كه طول و عرض مستطيل را از ورودي دريافت كرده محيط و مساحت آنرا محاسبه و چاپ كند.2ـ فلوچارتي رسم نمائيد كه شعاع دايره‌اي را از ورودي دريافت كرده، محيط و مساحت آنرا محاسبه و چاپ نمايد.3ـ فلوچارتي رسم كنيد كه سه عدد Third , second, first را از ورودي دريافت كرده، محتويات آنها را جابجا نموده، حاصل را در خروجيچاپ كند.22گروه آموزشی مهندسی ایران Iranian Engineering Group WWW.MOHANDE30.COM

اسلاید 23: 4ـ فلوچارتي رسم نمائيد كه دو عدد از ورودي دريافت كرده، سپس محتويات دو عدد را بدون استفاده از متغير كمكي جابجا كند.5ـ فلوچارتي رسم نمائيد كه عددي (درجه حرارت برحسب سانتيگراد) را از ورودي دريافت كرده سپس آنرا به درجه فارنهايت تبديل كند.23گروه آموزشی مهندسی ایران Iranian Engineering Group WWW.MOHANDE30.COM

اسلاید 24: دستورالعمل‌هاي شرطي در حل بسياري از مسائل يا تقريباً تمام مسائل نياز به استفاده از شروط جزء، نيازهاي اساسي محسوب مي‌شود. همانطور كه ما خودمان در زندگي روزمره با اين شرط‌ها سركار داريم. بطور مثال اگر هوا ابري باشد ممكن است چنين سخن بگوييم: اگر هوا باراني باشد سپس چتري برمي‌دارم. در غير اينصورت چتر برنمي‌دارم.24گروه آموزشی مهندسی ایران Iranian Engineering Group WWW.MOHANDE30.COM

اسلاید 25: در حالت كلي شرط را بصورت زير نمايش مي‌دهند:If شرط یا شروط thenعمل يا اعمال yes NOعمل يا اعمال بعدي25گروه آموزشی مهندسی ایران Iranian Engineering Group WWW.MOHANDE30.COM

اسلاید 26: مثال : فلوچارتي رسم نمائيد كه عددي را از ورودي دريافت كرده، فرد يا زوج بودن آن را تشخيص دهد.BeginRead(a)R a mod 2Write(‘odd’)Endif R=0 thenNoyesWrite(‘even’)26

اسلاید 27: BeginRead(a,b)max a Write(max)Endif b>maxNoyes max bمثال : فلوچارتي رسم كنيد كه دو عدد از ورودي دريافت كرده بزرگترين عدد را پيدا كرده در خروجي چاپ نمايد.27

اسلاید 28: BeginRead(a,b,c)min a Write(min)Endif b<min thenNoyesmax bif c<min thenyesmin c Noمثال : فلوچارتي رسم نمائيد كه سه عدد از ورودي دريافت كرده، كوچكترين عدد را يافته در خروجي چاپ نمايد:28

اسلاید 29: نمونه اجراي فلوچارت بالا بصورت زير مي‌باشد:29

اسلاید 30: تمرين1- فلوچارتي رسم كنيد که عددي را از ورودي دريافت كرده، قدر مطلق عدد را در خروجي چاپ كند.2- فلوچارتي رسم نمائيد كه عددي از ورودي دريافت كرده مثبت، منفي يا صفر بودن عدد را تشخيص داده، در خروجي با پيغام مناسب چاپ كند.3- فلوچارتي رسم نمائيد كه عددي را از ورودي دريافت كرده، بخشپذيري آن بر 3 و 5 را بررسي نمايد.4ـ فلوچارتي رسم نمائيد كه ضرايب يك معادله درجه دوم را از ورودي دريافت كرده، ريشه‌هاي آن را محاسبه در خروجي چاپ كند.30

اسلاید 31: حلقه‌هادر حل بسياري از مسائل با عملياتي روبرو مي‌شويم ، كه نياز به تكرار دارند و عمل تكرار آنها به تعداد مشخصي انجام مي‌گيرد. فرض كنيد، بخواهيم ميانگين 100 عدد را محاسبه كنيم، در اينصورت منطقي بنظر نمي‌رسد كه 100 متغير مختلف را از ورودي دريافت كنيم سپس آنها را جمع كنيم.31

اسلاید 32: انواع حلقه هاحلقه های با تکرار مشخصحلقه های با تکرار نا مشخص32

اسلاید 33: حلقه های با تکرار مشخصدر اين نوع حلقه‌ها تعداد تكرار مشخص مي‌باشد اين حلقه از اجزاء زير تشكيل مي‌شود:1ـ انديس حلقه 2ـ مقدار اوليه براي انديس حلقه 3- مقدار افزاينده براي انديس حلقه (معمولا يك واحد در هر مرحله)4ـ مقدار نهايي (تعداد تكرا حلقه)5ـ شرطي براي كنترل تعداد تكرار حلقه33

اسلاید 34: i 1 if i<=n yesNoمجموعه دستورات حلقه i i+1اتمام كار حلقه اين حلقه‌ها را غالباً با فلوچارت بصورت زير نمايش مي‌دهند:34

اسلاید 35: مثال : فلوچارتي رسم نمائيد كه عدد n را از ورودي دريافت كرده، مجموع اعداد از يك تا n را محاسبه كند.i انديس حلقه n مقدار نهايي 35

اسلاید 36: BeginRead(n)I 1 sum 0if I<=nyesNoWrite(sum)Endsum sum+II I+1حلقه36

اسلاید 37: نمونه اجراي فلوچارت بالا بصورت زير است:37

اسلاید 38: مثال : فلوچارتي رسم كنيد كه n عدد از ورودي دريافت كرده، بزرگترين مقدار از بين n عدد را پيدا كرده در خروجي چاپ نمايد.انديس حلقه iمقدار نهايي nبزرگترين مقدار Max 38

اسلاید 39: BeginI 2 max a if i<=n thenyesNowrite(max)Endi i+1حلقهRead(a)Read(n)if a > maxmax aNoyes39گروه آموزشی مهندسی ایران Iranian Engineering Group WWW.MOHANDE30.COM

اسلاید 40: مثال : فلوچارتي رسم نمائيد كه n , x ، دو عدد صحيح مثبت را از ورودي دريافت كرده سپس x به توان n را محاسبه كند.انديس حلقه iمقدار نهايي nعدد به توان n pow40گروه آموزشی مهندسی ایران Iranian Engineering Group WWW.MOHANDE30.COM

اسلاید 41: Begini 1 pow 1 if i<=n thenyesNowrite(pow)Endpow pow*xحلقهRead(n,x)i i+141گروه آموزشی مهندسی ایران Iranian Engineering Group WWW.MOHANDE30.COM

اسلاید 42: حلقه‌هايي كه تعداد تكرار آنها مشخص نيست (در پاسكال به حلقه while مشهورند.)در اين حلقه‌ها با توجه به ورودي، تعداد تكرار مشخص مي‌شود. و دقيقاً نمي‌‌توان تعداد تكرار حلقه را بدون ورودي معين كرد. اين حلقه ها فقط شامل شرطي هستند كه تا زمانيكه برقرار باشد حلقه اجرا مي‌شود.42گروه آموزشی مهندسی ایران Iranian Engineering Group WWW.MOHANDE30.COM

اسلاید 43: If شرط يا شروطمحموعه دستورالعملها و جاگزينها yesNoدر حالت كلي اين نوع حلقه‌ها بصورت زير نمايش داده مي‌شوند:43

اسلاید 44: مثال: فلوچارتي رسم كنيد كه عددي را از ورودي دريافت كرده سپس تعداد ارقام آن را شمرده در خروجي چاپ نمايد.عدد خوانده شده N تعداد ارقام count 44

اسلاید 45: Begincount 0 if N>0 thenyesNowrite(count)EndN N div 10حلقهRead(N)count count+145

اسلاید 46: مثال : فلوچارتي رسم نمائيد كه عددي از ورودي دريافت كرده، سري فيبوناچي قبل از آنرا توليد نمايد.در حالت كلي جملات سري بصورت:fk=fk-1+fk-2عدد خوانده شدهNجمله سوم سري f3جمله دوم سري f2جمله اول سري f1 46

اسلاید 47: BeginF1 0f2 1 if f3>N thenyesNoEndحلقهRead(N)f1 f2f2 f3f3 f1+f2f3 f1+f2 write(f3)47

اسلاید 48: تمرين 1- فلوچارتي رسم نمائيد كه عددي از ورودي دريافت كرده، كامل بودن آنرا بررسي نمايد. (عدد كامل، عددي است كه مجموع مقسوم‌عليه‌هاي آن با خودش برابر باشد.)2- فلوچارتي رسم كنيد كه N را از ورودي دريافت كرده، N جمله سري فيبوناچي را توليد نماید.3ـ فلوچارتي رسم نمائيد كه دو عدد N , M را از ورودي خوانده، بزرگترين مقسوم‌عليه مشترك دو عدد را محاسبه و چاپ كند.48

اسلاید 49: حلقه‌هاي تودرتو الگوريتم‌‌هايي كه تا حال بكار برديم، فقط شامل يك حلقه بودند.در صورتي كه در بسياري از مسائل ممكن است نياز به استفاده از چندحلقه در داخل هم باشيم. در اين نوع حلقه‌ها بايد دقت بيشتري به خرج دهيم، تا مشكلي پيش نيايد. اگر از حلقه‌هاي نوع اول بصورت تودرتو استفاده كنيم در اينصورت براي هر حلقه شرط نهايي و انديس اوليه جداگانه بايد تعريف كنيم .49

اسلاید 50: در حلقه‌هاي تودرتو به ازاي يكبار تكرار حلقه اوليه، حلقه داخلي به اندازه مقدار نهايي خود تكرار مي‌شود. در كل اگر حلقه اوليه n بار تكرار شود و حلقه داخلي m بار، در اينصورت كل حلقه : بار تكرار خواهد شد.50

اسلاید 51: فلوچارت حلقه‌هاي تودرتو را مي‌توان بصورت زير نشان داد:i 1 if j<=m thenNoحلقهj j+1yes...if i<=n thenj 1مجموعه دستورات و جايگزيني ها مجموعه دستورات و جايگزيني ها i i+1AAyesNoاتمام كار حلقه هاي تو در تو51

اسلاید 52: انديس حلقه اول I ورودي N ‌محاسبه فاكتوريل fact انديس حلقه داخلي j مجموع Sum مثال : فلوچارتي رسم نمائيد كه N را از ورودي دريافت كرده، مجموع سري زير را محاسبه نمايد:52

اسلاید 53: i 2sum 1 Aif j<=i Nofact fact*jyesif i<=N fact 1j 2i i+1yesNoRead(N)Endsum sum+i/factAj j+1Write(sum)53

اسلاید 54: تمرينات آخر فصل1- فلوچارتي رسم نمائيد كه N عدد از ورودي دريافت كرده تعداد اعداد اول و كامل را شمرده در خروجي چاپ نمايد.2- فلوچارتي رسم نمائيد كه N , X را از ورودي خوانده مقدار سري زير را محاسبه كند:54

اسلاید 55: 3- فلوچارتي رسم نمائيد كه عددی را از ورودي دريافت كرده مقلوب عدد را محاسبه و در خروجي چاپ كند.4ـ فلوچارتي رسم كنيد كه تاريخ تولد شخصي را از ورودي خوانده، سن شخص را با تاريخ روز، محاسبه نموده در خروجي چاپ كند.5- فلوچارتي رسم نمائيد كه (m>n) N ,M را از ورودي دريافت كرده سري فيبوناچي بين N ,M را توليد كرده، در خروجي چاپ كند.55

اسلاید 56: فصل 2كاربرد آرايه ها در الگوريتم ها هدفهاي كليشناخت الگوریتم های لازم برای جستجو و مرتب سازیشناخت آرایه ها و مفهوم آن مقایسه انواع روش های جستجو با هم56

اسلاید 57: هدفهاي رفتاري از آرایه ها در حل مسئله استفاده کند . با استفاده از آرایه ها لیستی را مرتب نماید . در صورت لزوم در لیستی جستجو انجام دهد . دانشجو پس از مطالعه اين فصل بايد بتواند:57

اسلاید 58: مقدمهفرض كنيد بخواهيم اطلاعات 100 كارمند را از ورودي بخوانيم و سپس آنها را مرتب كنيم، در اينصورت بايد وروديها را در جايي از حافظه ذخيره كنيم. در زبانهاي برنامه‌نويسي معمولا از آرايه براي ذخيره اطلاعات در حافظه استفاده مي‌كنند. در آرايه‌ها ما با توجه به تعداد وروديها، طول آن را مشخص مي‌كنيم. سپس داده‌ها را خوانده در آن قرار مي‌دهيم.58

اسلاید 59: تعريف آرايهخانه‌هاي پشت سر هم از حافظه، كه همنوع بوده و توسط يك اسم معرفي مي‌شوند، آرايه نام دارد. نحوه دسترسي به هر يك از اعضاء آرايه، از طريق انديس آرايه امكانپذير است . براي تعريف آرايه ابتدا طول آرايه كه در حقيقت تعداد خانه‌هاي آن را مشخص مي‌كند، معين مي‌كنيم. سپس نوع خانه‌ها بايد معين شوند.در فلوچارت‌ها آرايه‌ها را بصورت زير نمايش مي‌دهيم:Name[ 1 .. Length ] طول آرايه اسم آرايه59

اسلاید 60: براي خواندن يك آرايه از ورودي از حلقه‌ها استفاده مي‌كنيم. فلوچارت خواندن آرايه از ورودي بصورت زير مي‌باشد:a[1..100]if i<=100 Noyes Read(a[i])i i+1i 160

اسلاید 61: با توجه به فلوچارت بالا براي دسترسي به عنصر iام آرايه در حالت كلي بصورت : Nam [ index ] انديس آرايه اسم آرايه عمل مي‌كنند.مثال: فلوچارتي رسم كنيد كه يك آرايه حداكثر 100 عنصري را از ورودي دريافت كرده، سپس آن را خروجي نمايش دهد.61

اسلاید 62: 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+1NoEnd62

اسلاید 63: مثال : فلوچارتي رسم كنيد كه عددي را از ورودي دريافت كرده آن را به مبناي 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+163

اسلاید 64: a[1..100]i 1k 3a[1] 2a[2] 1 Read(N)مثال : فلوچارتي رسم نمائيد كه عددي از ورودي دريافت كرده سپس اعداد اول قبل از آن را توليد نموده ، در يك آرايه قرار دهد.64

اسلاید 65: 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 1NoyesNoA65

اسلاید 66: جستجو و مرتب سازي ( search and sort )يكي از مسائلي كه در بحث طراحي الگوريتم بسيار مهم است، بحث مرتب‌سازي و جستجو مي‌باشد. منظور از جستجو اينست كه يك مقداري را از يك ليست جستجو كنيم و منظور از مرتب‌سازي اينست كه يك ليست مرتب از داده‌ها را توليد كنيم.براي جستجو و مرتب‌سازي الگوريتم‌هاي مختلفي وجود دارد در زير الگوريتم‌های اوليه، براي جستجو و مرتب‌سازي را بررسي مي‌كنيم.66

اسلاید 67: الگوریتم های جستجو ( search)دو الگوريتم زير غالباً براي جستجو بكار مي‌روند:جستجوي خطي linear searchجستجوي دودوئی binary search67

اسلاید 68: در جستجوي خطي عبارت مورد جستجو را به ترتيب با اولين، دومين و … عنصرآرايه مقايسه مي‌كنيم اگر عنصر مورد جستجو پيدا شد اندیس آن را نمايش مي‌دهيم. جستجوي خطي linear search68گروه آموزشی مهندسی ایران Iranian Engineering Group WWW.MOHANDE30.COM

اسلاید 69: فلوچارت جستجوي خطي بصورت زير است: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)Endyesyes69گروه آموزشی مهندسی ایران Iranian Engineering Group WWW.MOHANDE30.COM

اسلاید 70: جستجوي دودوئی binary searchدر جستجوي دودوئی ، ليست مورد جستجو، مرتب مي‌باشد. لذا براي جستجو اعمال زير انجام مي‌شود:1- عنصر X با عنصر وسط آرايه كه انديس آن برابر middle (low+high)/2 مقايسه مي‌شود.70گروه آموزشی مهندسی ایران Iranian Engineering Group WWW.MOHANDE30.COM

اسلاید 71: 2ـ اگر x از عنصر وسط كوچكتر باشد، عنصر مورد نظر احتمالاً در قسمت بالای ليست قرار دارد. لذا آرايه با انديس، جديد در نظر گرفته مي‌شود و قسمت پايين ليست از فضاي جستجو حذف مي‌شود.3ـ اگر x از عنصر وسط آرايه بزرگتر باشد قسمت بالاي ليست حذف مي‌شود و فضاي جستجو، قسمت پايين آرايه خواهد بود.4- اگر x برابر عنصر وسط باشد عمل جستجو خاتمه مي‌پذيرد.71گروه آموزشی مهندسی ایران Iranian Engineering Group WWW.MOHANDE30.COM

اسلاید 72: مرتب‌سازي بحث بعدي اين فصل مي‌باشد. براي مرتب كردن داده‌ها نيز الگوريتم‌هاي مختلفي وجود دارد، كه هر كدام مزايا و معايب خاص خود را دارد. بحث مفصل در اين مورد را به فصل‌هاي بعد واگذار مي‌كنيم.مرتب سازي (sort )72گروه آموزشی مهندسی ایران Iranian Engineering Group WWW.MOHANDE30.COM

اسلاید 73: تمرين فلوچارتي رسم نمائيد كه عددي از ورودي دريافت كرده، اعداد كامل قبل از خود را توليد و در يك آرايه قرار دهد.فلوچارتي رسم نمائيد كه يك آرايه حداكثر 100 عنصري از ورودي دريافت كرده، عناصري از آن كه اول هستند را با صفر كردن حذف نمايد.فلوچارتي رسم نمائيد كه يك عدد حداكثر 20 رقمي را توسط آرايه‌اي از ورودي دريافت نمايد. سپس يك عدد تک رقمي را از ورودي خوانده در عدد 20 رقمي ضرب نموده، حاصل را در خروجي چاپ نمايد.73

اسلاید 74: فصل 3آشنايي با كامپيوترهدفهاي كليشناخت سخت‌افزارهاي لازم براي كامپيوترهاي شخصي شناخت كامپيوترهاي نسل قديم و امروزي بررسي نرم‌افزارها و انواع آن74

اسلاید 75: هدفهاي رفتاري كامپيوترهاي نسل جديد را با كامپيوترهاي نسل قديم مقايسه كند. سخت‌افزارهاي لازم براي كامپيوترهاي شخصي را بشناسد. انواع حافظه، مزايا و معايب آنها را شناخته و با هم مقايسه نمايد. سيستم عامل و انواع آن را مقايسه نمايد. نرم‌افزار و زبانهاي برنامه‌نويسي را تعريف كند.دانشجو پس از مطالعه اين فصل بايد بتواند:75

اسلاید 76: كامپيوترهاي قديمياولين كامپيوتر بزرگ (Super Computer) همه منظوره ديجيتال الكترونيك، تحت عنوان ENIAC در سال 1946 ميلادي در دانشگاه پنسيلوانيا ساخته شد. اين كامپيوتر با سرمايه ارتش آمريكا طراحي شد. وزن اين كامپيوتر 30 تن و ابعاد آن 50×30 فوت بود. اين كامپيوتر براي محاسبه جدول پرتابه‌ها، پيش‌گويي وضع آب و هوا و محاسبات انرژي اتمي بكار مي‌رفت.76

اسلاید 77: در كامپيوترهاي اوليه از لامپهاي خلاء بعنوان عنصر الكترونيكي پايه استفاده مي‌كردند. در اين ماشين‌ها 19000 لامپ خلاء استفاده شده بود و براي انرژي مصرفي لامپ‌ها و همچنين دستگاههاي تهويه و خنك‌كننده ماشين حدود kw 130 انرژي الكتريكي مصرف مي‌شد. اين ماشين‌ها داراي حجم زيادي بودند و سطحي را معادل 9015 مترمربع اشغال مي‌كردند. اين كامپيوترها به كامپيوترهاي نسل اول معروف شدند. 77

اسلاید 78: كامپيوترهاي امروزي با بكارگيري ريزپردازنده به كامپيوترهاي نسل چهارم معروفند. البته نسل‌هاي جديد ديگر كامپيوترها نيز به بازار ارائه مي‌شود. در كامپيوترهاي امروزي سرعت‌ پردازش‌ بسيار بالا، حجم‌ اجزاء سخت‌افزاري بسيار كوچك، حجم حافظه بالا و غيره آنها را از نسل هاي ديگر متمايز مي‌سازد. كامپيوترهاي امروزي78

اسلاید 79: اجزاء تشکيل دهنده کامپيوتر عبارتند از : سخت افزار نرم افزار79

اسلاید 80: سخت افزارInputOut putprocessپردازشوروديخروجي80

اسلاید 81: كامپيوترهاي امروزي معمولاً از قطعات زير تشكيل مي‌شوند: دستگاههاي ورودي حافظه‌هاي جانبي حافظه‌هاي اصلي واحد پردازشگر مركزي دستگاههاي خروجي 81

اسلاید 82: نرم‌افزار يكي از بخش‌هاي اساسي كامپيوتر به شمار مي‌آيد، كه در واقع سخت‌افزار را بكار مي‌گيرد. بعبارت ديگر رابط بين كاربر و سخت‌افزار را نرم‌افزار مي‌نامند. نرم‌افزار در حقيقت روح و جان يك كامپيوتر است، كه به سخت‌افزار هويت مي‌بخشد. نرم افزار82

اسلاید 83: سيستم عامل (OS: Operating System) مشهورترين نوع نرم‌افزارهاي سيستمي مي‌باشد. كه مديريت منابع سيستمي را بر عهده دارد. سيستم‌عامل، همچنين ارتباط بين كاربر و اجزاء سخت‌افزاري و نرم‌افزاري ديگر را برقرار مي‌كند. نرم افزار سيستم عامل83

اسلاید 84: سخت‌افزارسيستم‌عاملبرنامه كاربرديكاربر84

اسلاید 85: زبانهاي برنامه‌نويسي نرم‌افزارها توسط زبانهاي برنامه‌نويسي نوشته مي‌شوند. زبانهاي برنامه‌نويسي، يك سيستم ارتباطي هستند كه توسط آنها مي‌توان دستورات لازم را به ماشين انتقال داد.هرزبان برنامه‌نويسي به مجموعه‌أي از علايم، قواعد و دستورالعمل‌ها گفته مي‌شود كه امكان ارتباط با كامپيوتر را جهت بيان كاري يا حل مسئله‌اي فراهم مي‌كند. 85

اسلاید 86: زبانهاي سطح بالازبانهاي سطح پايينزبانهاي سطح ميانيدر حالت كلي زبانهاي برنامه‌نويسي را به سه دسته زير تقسيم‌بندي مي‌كنند:86

اسلاید 87: Source programObject programCompilerكامپايلر برنامه نوشته در يك زبان سطح بالا را به برنامه مقصد تبديل مي‌كند. 87

اسلاید 88: زبان Pascal در اين كتاب زبان پاسكال (Pascal) را براي آموزش و نوشتن برنامه‌ها انتخاب كرديم. اين زبان كه به افتخار بلز پاسكال دانشمند فرانسوي قرن هفدهم ميلادي، پاسكال نامگذاري شده است، در اواخر سال 1960 و اوايل 1970 توسط پروفسور نيكلاس ويژت در انستيتو فني فدرال سوئيس مطرح گرديد 88

اسلاید 89: فصل 4 ساختار برنامه در زبان پاسکال هدفهاي كليشناخت ساختار يك برنامه در زبان پاسكال شناخت اجزاي تشكيل دهنده يك برنامه بررسي دستگاههاي خروجي و دستورات لازم در زبان پاسكال براي توليد خروجي 89

اسلاید 90: هدفهاي رفتاري اجزاء لازم براي نوشتن برنامه در زبان پاسكال را بداند. يك شناسه صحيح در زبان پاسكال را تعريف كند. ساختار يك برنامه در زبان پاسكال و اعلانهاي مربوط به برنامه را تعريف نمايد. يك برنامه ساده به زبان پاسكال كه فقط خاصيت خروجي دارد، بنويسد. دانشجو پس از مطالعه اين فصل بايد بتواند:90

اسلاید 91: کلمات ذخيره‌شده ( Reserved Words )شناسه‌ها ( identifier ) اجزاي تشکيل‌دهنده يک برنامه 91

اسلاید 92: کلمات ذخيره شده، کلماتي هستند که مترجم زبان آنها را مي‌شناسد و معناي خاصي براي زبان دارند. مترجم زبان به محض مشاهده اين کلمات اعمال خاصي را انجام مي‌دهد. هر زبان داراي تعداد مشخصي کلمات ذخيره شده مي‌باشد و اين تعداد قابل افزايش توسط برنامه‌نويس نيست. کلمات ذخيره‌شده ( Reserved Words )92

اسلاید 93: ليست کلمات ذخيره شده در پاسکال عبارتند از: 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 shl93

اسلاید 94: شناسه در پاسکال براي نامگذاري ثابتها، تايپها، پروسيجروها، توابع، ميدانهاي يک رکورد، برنامه و همچنين يونيت مورد استفاده قرار مي‌گيرد. شناسه‌ها ( identifier )94

اسلاید 95: در حالت کلي دو نوع شناسه وجود دارد :id هاي استاندارد: اين نوع id ها از قبل در زبان پاسکال تعريف شده‌اند و در برنامه‌ها، معناي خاصي دارند . id هاي غيراستاندارد: اين نوع id ها بوسيله کاربر بطور مجزا تعريف مي‌شوند و اصطلاحاً به آنها userdefined گفته مي‌شود.95گروه آموزشی مهندسی ایران Iranian Engineering Group WWW.MOHANDE30.COM

اسلاید 96: ساختار برنامه در زبان پاسکال اجزاء اصلي يک برنامه به زبان پاسکال بصورت زير مي‌باشد:عنوان برنامهقسمت تعاريف برنامه قسمت دستور العملها 96گروه آموزشی مهندسی ایران Iranian Engineering Group WWW.MOHANDE30.COM

اسلاید 97: قسمت تعاريف برنامهاعلان ثابتها Constant Declarationاعلان انواع Type Declarationاعلان متغيرها Declaration Variable اعلان برچسبها Declaration Label 97گروه آموزشی مهندسی ایران Iranian Engineering Group WWW.MOHANDE30.COM

اسلاید 98: درحالت کلي مي‌توان شکل يک برنامه در زبان پاسکال را بصورت زير بيان کرد:استفاده از کلمه ذخيره شده Program و اسم برنامه ( که مي‌تواند بکار برده نشود ) قسمت تعاريف شناسه‌ها بلوک اصلي برنامه که با Begin شروع و به End همراه نقطه ( . ) ختم مي‌شود.هر دستور در پاسکال به ( ; ) ختم مي‌شود.98گروه آموزشی مهندسی ایران Iranian Engineering Group WWW.MOHANDE30.COM

اسلاید 99: نمودارهاي يک برنامه و بلوک بترتيب به صور ت زير مي‌باشد: Programشناسه)شناسه(;block0,BeginStatementEnd.;99گروه آموزشی مهندسی ایران Iranian Engineering Group WWW.MOHANDE30.COM

اسلاید 100: مشهورترين دستگاههاي خروجي عبارتنداز: خروجي ( Output ) صفحه نمايش Monitor چاپگر Printer ترمينال Terminale رسام Plotter 100

اسلاید 101: مثال هاي حل شده Program Print ( output ) ;Begin Writeln ( Pascal Language ) ; Writeln ( Hello ) ;End.101

اسلاید 102: خروجي برنامه بالا بصورت زير مي‌باشد: Pascal Language Hello 102

اسلاید 103: فصل 5انواع عملگرها و داده‌ها در زبان پاسکالهدفهاي كليشناخت انواع داده‌هامعرفي انواع عملگرها در زبان پاسكال بررسي اولويت عملگرهامعرفي دستورات جايگزيني در پاسكال103

اسلاید 104: دانشجو پس از مطالعه اين فصل بايد بتواند: هدفهاي رفتاريانواع عملگرها در زبان پاسكال را بكار ببرد انواع داده‌ها براي يك برنامه را تعريف كند.اولويت عملگرها در يك عبارت را تشخيص دهد.يك برنامه ساده با عمليات معمولي را بنويسد.104

اسلاید 105: عملگرها عملگرها نمادهايي هستند که براي انجام اعمال خاصي مورد استفاده قرار مي‌گيرند.عملگرها براي انجام اعمال خاصي روي عملوندها ( Operands ) بکار مي‌روند. با توجه به نوع عملگر ممکن است يک يا دو عملوند وجود داشته باشد. عملگرها در زبان پاسکال از تنوع زيادي برخوردارند. 105

اسلاید 106: در پاسکال چهار دسته عملگر وجود دارند :محاسباتي رابطه اي منطقي بيتي106

اسلاید 107: عملگرهاي محاسباتي107

اسلاید 108: عملگرهاي رابطه اي108

اسلاید 109: عملگرهاي منطقي 109

اسلاید 110: عملگرهاي بيتي110

اسلاید 111: تقدم عملگرها111

اسلاید 112: انواع داده‌ها ( data types ) داده‌هاي ساده (Simple data type) داده‌هاي ساخت‌يافته ( ( Structural Data Types داده‌هاي اشاره‌گر (Pointer Data Types)112

اسلاید 113: داده‌هاي ساده (Simple data type)صحيح ( integer )اعشاري (حقيقي) نوع منطقي (Boolean type) نوع کاراکتري (Char type) نوع رشته اي (String type) 113

اسلاید 114: صحيح ( integer )114

اسلاید 115: اعشاري (حقيقي)115

اسلاید 116: داده‌هاي ساخت‌يافته ( ( Structural Data Types انواع داده‌هاي ساخت‌يافته عبارتند از:آرايه‌هارکوردهامجموعه‌هافايلها116

اسلاید 117: داده‌هاي اشاره‌گر (Pointer Data Types)ممکن است در نوشتن برنامه، نوع داده‌هاي بحث شده در بالا به دلايل مختلف از جمله مشخص نبودن تعداد وروديهاي مسئله و غيره مشخص نباشد لذا نياز به متغيرهايي هست که بتوانند آدرس متغيرهاي ديگر را در. خود نگه دارند، اين نوع داده‌ها، داده‌هاي اشاره‌گر نام دارند117

اسلاید 118: متغيرها (Variables) متغير، محلي از حافظه است که داراي نوع و اسم مي‌باشد. نوع متغير همان نوع داده بوده و اسم متغير از قواعد اسم‌گذاري شناسه تبعيت مي‌کند.در پاسکال براي معرفي متغيرها بصورت زير عمل مي‌کنند:Var (کلمه ذخيره شده) نوع متغير: اسم متغير ;118

اسلاید 119: ثابتها (Constants) يک ثابت نام شناسه‌اي است که در آغاز يک برنامه، يک مقدار در آن جاگزين مي‌شود. درست مانند متغيرها. ثابت‌ها را مي‌توان بعنوان خانه‌هايي از حافظه در نظر بگيريم که مقدار داده‌ها در آنها ذخيره مي‌شود ولي مقدار ثابت مشخص مي‌باشد، طوري که نمي‌توان مقدار يک ثابت را در برنامه خود بوسيله يک دستور تغيير داد.: براي تعريف يک ثابت بصورت زيرعمل مي‌کنيم مقدار ثابت = اسم متغير Const 119

اسلاید 120: دستور جايگزيني براي قرار دادن يک مقدار يا مقدار يک متغير داخل يک متغير ديگر، از دستور جايگزيني استفاده مي‌کنند. شکل کلي يک دستور جايگزيني در پاسکال بصورت زير است: عبارت محاسباتي = : اسم شناسه عبارت قياسي يا عبارت منطقي 120

اسلاید 121: افزودن توضيحات به برنامه (Comment) افزودن مطلب توضيحي در درون خود برنامه عملي پسنديده و مطلوب است بدين ترتيب که بعد از مدتي امکان فراموشي کار با برنامه از بين مي‌رود و در کل مي‌توان گفت که نوشتن توضيحات در برنامه خوانايي آن را بالا مي‌برد. در پاسکال توضيحات بين دو آکولاد محصور مي‌شوند.{ This is comment } { This program written by A. Pascal }121

اسلاید 122: مثال جابجا کردن مقدار دو متغير 151715 17151715171715aa ab bb temptempab122

اسلاید 123: 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 123

اسلاید 124: نکاتي چند در مورد برنامه‌نويسي استفاده از اسامي با مفهوم براي متغير‌ها استفاده از دستور Const در صورتي که مقدار ثابت در برنامه وجود داشته باشد.سوال جوابي بودن برنامه (ورودي‌ها و خروجي‌ها بايد داراي پيغام مناسب باشند)نوشتن برنامه با فرمت مناسب (رعايت قرار گرفتن خطوط مختلف برنامه زير هم و فاصله گذاشتن آنها از اول سطر و غيره)124

اسلاید 125: تمرينات حاصل عبارتهاي زير را بدست آوريد: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 ))125

اسلاید 126: : حاصل عبارت‌هاي منطقي را به ازاء مقادير زير مشخص کنيد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 = ?126

اسلاید 127: تمرينات برنامه‌نويسي برنامه‌اي بنويسيد که ابعاد مثلث که عبارتند از 3 , 1.3 را در نظر گرفته محيط و مساحت آن را محاسبه و با پيغام مناسب در خروجي چاپ کند.برنامه‌اي بنويسيد که دو متغير صحيح با مقادير 3 , 15 را در نظر گرفته محتويات دو عدد را بدون استفاده از متغير کمکي جابجا نمايد.برنامه‌اي بنويسيد که سه عدد بنام هاي Third , Second , First بترتيب با مقادير 17 , 15 , 13 را در نظر گرفته بطور چرخشي مقادير آنها را جابجا نموده در خروجي با پيغام مناسب چاپ کند.127گروه آموزشی مهندسی ایران Iranian Engineering Group WWW.MOHANDE30.COM

اسلاید 128: فصل 6ورودي و خروجي هدفهاي كليمعرفي خروجي فرمت‌بندي شدهWriteln معرفي دستورات خروجي بررسي دستورات ورودي Read و ReadLn 128گروه آموزشی مهندسی ایران Iranian Engineering Group WWW.MOHANDE30.COM

اسلاید 129: هدفهاي رفتاريعبارات مورد نظر را در خروجي نمايش دهد.عبارات خروجي را با فرمت مناسب چاپ كند.متغيرهاي مورد نياز برنامه را از ورودي دريافت نمايد.برنامه‌هاي ساده به زبان پاسكال بنويسد.دانشجو پس از مطالعه اين فصل بايد بتواند:129گروه آموزشی مهندسی ایران Iranian Engineering Group WWW.MOHANDE30.COM

اسلاید 130: خروجي با دستور Write اين دستور براي نوشتن اطلاعات در خروجي بکار مي‌رود. اطلاعات خروجي مي‌توانند ثابتهاي عددي، مقادير متغيرها، عبارات و غيره باشند. شکل دستور در حالت کلي بصورت زير است: (....... و متغير2 و متغير1 )write يا (....... و عبارت 2 وعبارت1 ) يا (....... و ثابت 2 وثابت 1 )130گروه آموزشی مهندسی ایران Iranian Engineering Group WWW.MOHANDE30.COM

اسلاید 131: مثال 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 = 25131گروه آموزشی مهندسی ایران Iranian Engineering Group WWW.MOHANDE30.COM

اسلاید 132: خروجي با دستور Writeln اين دستور همانند دستور Write عمل مي‌کند با اين تفاوت که بعد از اجرا، کنترل را به ابتداي سطر بعد منتقل مي‌کند در نتيجه موجب چاپ داده‌هاي بعدي در ابتداي سطر بعد مي‌شود.132

اسلاید 133: 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 133

اسلاید 134: خروجي فرمت‌بندي شده اگر بخواهيم اطلاعات با فاصله هاي مشخص يا در مکان مشخصي در صفحه نمايش قرار گيرند، بايد فرمت چاپ را در دستورات بيان شده مشخص کنيم.134

اسلاید 135: طريقه تعيين فرمت چاپ براي اعداد صحيح فرمت اعداد صحيح بصورت زير مشخص مي‌شود: ( طول ميدان: داده صحيح ) Writeln يا Write135

اسلاید 136: اگر طول ميدان از طول ارقام عدد صحيح بيشتر تعريف شود، عدد در منتهي‌اليه سمت راست ميدان نوشته مي‌شود.اگر طول ميدان از طول ارقام عدد صحيح کمتر تعريف شود، طول ميدان به اندازه تعداد ارقام در نظر گرفته مي‌شود و طول ميدان تعريف شده بي‌اثر خواهد بود.در تعريف طول ميدان براي متغيرها يا داده‌هايي از نوع صحيح به نکات زير توجه کنيد:136

اسلاید 137: X:= 3200 ; A: = 12 ;B: = 217 ;Write ( X:3 , A:5 , B:5 ) ; مثال : خروجي 320012217137

اسلاید 138: طول ميدان اعداد اعشاري براي نمايش اعداد اعشاري بصورت دلخواه، مي توان با تعريف طول ميدان و تعداد ارقام اعشاري، عدد مزبور را نمايش داد. : در حالت کلي طول ميدان را مي‌توان به صورت زير تعريف کرد Write ( تعداد ارقام بعد از مميز: طول ميدان: متغير اعشاري ) يا Writeln138

اسلاید 139: در تعريف فرمت براي اعداد اعشاري به نکات زير بايد توجه کرد: اگر طول ميدان بزرگتر از تعداد ارقام عدد ذکر شود، عدد در منتهي اليه سمت راست ميدان چاپ مي‌شود.اگر فقط طول ميدان ذکر شود، عدد به صورت نماد علمي در طول ميدان مشخص شده چاپ می شود .از آنجائي که براي نمايش اعداد در نماد علمي حداقل 8 محل مورد نياز است، لذا هنگامي که تنها طول ميدان ذکر شده باشد، اگر از 8 رقم کمتر باشد، حداقل 8 رقم در نظر گرفته مي‌شود.139

اسلاید 140: هنگامي که طول ميدان همراه با تعداد ارقام بعد از مميز ذکر شود، اگر طول ميدان کوچکتر از مقدار عدد باشد، پاسکال تنها طول ميدان را به اندازه‌اي که مورد نياز است تصحيح کرده و آنرا برابر اندازه واقعي که عدد در آن قرار مي‌گيرد، اصلاح مي‌کند. اگر تعداد ارقام بعد از مميز زياد باشد و تعداد ارقام بعد از مميز ذکر شده در طول ميدان کمتر از تعداد ارقام اعشاري عدد باشد، تعداد ارقام اعشار مطابق درخواست برنامه‌نويس نشان داده خواهد شد و رقم آخر اعشار آن نسبت به عدد بعدي گرد مي‌شود.140

اسلاید 141: طول ميدان کاراکترها و رشته‌ها براي نمايش رشته‌ها و کاراکترهاي با طول ميدان بصورت زير عمل مي‌کنيم. Write ( طول ميدان: متغير يا عبارت رشته‌اي يا کاراکتري )در توربو پاسکال، کليه موارد گفته شده در مورد اعداد صحيح براي رشته‌ها نيز صادق است.141

اسلاید 142: ورودي با Readln , Read از اين دستور براي خواندن داده ها و اختصاص آنها به متغيرها استفاده مي‌شود. در خواندن داده ها به دو موضوع بايد دقت شود: 1- منبع داده‌ها يعني دستگاه ورودي که از آن داده‌ها خوانده مي‌شود.. 2- متغيري که داده‌هاي خوانده شده در آن قرار مي‌گيرد142

اسلاید 143: شکل کلي دستور ورودي Read بصورت زير مي‌باشد:;( ..... و متغير 2 و متغير 1Read ( اين دستور عمل خواندن داده‌ها و ذخيره آنها در متغيرها را انجام مي‌دهد و پس از اتمام عمل خواندن کنترل را براي خواندن و نوشتن‌هاي بعدي. در همان خط نگه مي‌دارد143

اسلاید 144: 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 }مثال جابجا کردن محتويات دو عدد144

اسلاید 145: خروجي برنامه بالا به صورت زير مي‌باشد:Please Enter two numbers 15 17First = 17 second = 15 145

اسلاید 146: تمرينات 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 ) ;: خروجي قطعه برنامه زير را تعيين کنيد146

اسلاید 147: اگر متغير 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 ) ; 147

اسلاید 148: تمرينات برنامه نويسيبرنامه‌اي بنويسيد که دو عدد را از ورودي دريافت کرده و محتويات آنها را بدون استفاده از متغير کمکي جابجا نمايد. برنامه‌اي بنويسيد که سه عدد صحيح Third , Second , first را از ورودي با پيغام مناسب دريافت کرده سپس محتويات اين سه متغير را بصورت چرخشي جابجا نموده با پيغام مناسب در خروجي چاپ کند.148

اسلاید 149: برنامه‌اي براي يک حسابدار اداره جمع آوري ماليات بنويسيد که صورت حسابهاي ماليات را محاسبه نمايد.ورودي: شماره شناسايي ماليات دهنده بهاي ارزيابي شده نرخ ماليات خروجي: صورت حساب بافرمت مناسب شامل تمام داده‌هاي ورودي و ميزان بدهي 149گروه آموزشی مهندسی ایران Iranian Engineering Group WWW.MOHANDE30.COM

اسلاید 150: فصل 7ساختارهاي شرطي و كنترلي هدفهاي كليمعرفي دستور caseIf and Elseمعرفي دستور شرطي بررسي دستورات تكرار for ، while ، repeat untilمعرفي دستورات شرطي متداخلبررسي چند تابع و روال استاندارد زبان پاسکال150گروه آموزشی مهندسی ایران Iranian Engineering Group WWW.MOHANDE30.COM

اسلاید 151: ÷ هدفهاي رفتاري برنامه‌هايي را بنويسد كه در آنها نياز به استفاده از شرط وجود دارد. تفاوتهاي بين دستورات مختلف با if و else- if را تشخيص دهد. برنامه‌هايي كه نياز به تكرار تعدادي عمليات داشته باشند را بنويسد. در صورت نياز بتواند در برنامه‌ها، از روالها و توابع استاندارد زبان استفاده نمايد.دانشجو پس از مطالعه اين فصل بايد بتواند:151گروه آموزشی مهندسی ایران Iranian Engineering Group WWW.MOHANDE30.COM

اسلاید 152: دستورات شرطي بطور کلي توسط اينگونه دستورات مي‌توان بر حسب شرايط مختلف، تصميمات متفاوتي را اتخاذ نمود و برحسب برقرار بودن يا نبودن شرايط دستورات متفاوتي را اجرا نمود. دستورات شرطي در حالت کلي به دو نوع تقسيم مي‌شوند:if دستورCase دستور152

اسلاید 153: دستور if هرگاه در طول برنامه نياز به استفاده از شرط يا شروط داشته باشيم، از دستور ستفاده مي‌کنيم. If دستور if بطور کلي به سه شکل بر حسب نياز ممکن است ظاهر شود: ساده ifElse همراه if هاي متداخل if153

اسلاید 154: If – then در اين نوع دستور شرطي اگر شرط خاصي تحقق يافته باشد، عمل يا اعمال خاصي انجام مي‌شود. در غير اينصورت برنامه روال عادي خود را طي مي‌کند، در صورتي که شرط برقرار باشد ارزش منطقي Ture به خود مي‌گيرد و اگر شرط برقرار نباشد، ارزش منطقي False به خود خواهد گرفت.154

اسلاید 155: If – then ( ادامه )ifشرط ياشروطدستورThenشناسه ;شکل کلي دستور if بصورت زير مي‌باشد: then شرط يا شروط if ; دستور دياگرام دستور بالا بصورت زير مي‌باشد: 155

اسلاید 156: 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 positive156

اسلاید 157: در اين دستور ابتدا شرط بررسي مي‌شود، در صورتي که شرط برقرار باشد، عمل يا اعمال خاصي را انجام مي‌دهد و در صورتي که شرط برقرار نباشد، عمل يا اعمال بخصوص ديگري را انجام خواهد داد. اينگونه دستورات در واقع حالت توسعه يافته دستورات if مي‌باشند. دستور if همراه else 157

اسلاید 158: شکل کلي اين دستور بصورت زير است:if عبارت يا عبارات منطقي thenدستور1 ;else دستور2 ;ifعبارت يا عبارات منطقيthenدستورelse دستور;دياگرام دستور بصورت:158

اسلاید 159: 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 159

اسلاید 160: If عبارت منطقيThen Begin دستور 1 ; دستور 2 ; . . .End Else Begin دستور 1 ; دستور 2 ; . . . End ; صورت ديگر دستور160

اسلاید 161: If هاي متداخلهرگاه در نوشتن برنامه نياز به انتخاب يک شرط از بين چند شرط داشته باشيم، معمولاً از If متداخل استفاده مي‌کنند. در چنين مواقعي استفاده از If متداخل کارائي برنامه را بالا مي‌برد زيرا بجاي کنترل تمام شروط فقط تا زمانيکه شرط برقرار نشده، If ها بررسي مي‌شوند. بعد از برقرار شدن يکي از شروط، کنترل برنامه به بعد از If منتقل مي‌شود و اين در بهبود کارائي يک برنامه مي‌تواند بسيار موثر باشد.161

اسلاید 162: در حالت کلي If متداخل به صورت هاي زير ممکن است، در برنامه ظاهر شود.... elseدستور 3 ;دستور2then عبارت شرطي3 else Ifelseدستور2دستور 1then عبارت شرطي 2 else ifthen عبارت شرطي2 if دستور 1then عبارت شرطي 1 ifthen عبارت شرطي1 if ( 2162

اسلاید 163: مثال : برنامه‌اي بنويسيد که نمره دانشجوئي را از ورودي دريافت کرده، با توجه به مقدار نمره يکي از خروجي هاي زير را نمايش دهد:Grade خروجي17 – 20 A 14 - 17 B12 – 14 C10 – 12 D0 – 10 F 163

اسلاید 164: 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 }164

اسلاید 165: دستور Case زبان پاسکال دستورCase را بصورت زير در نظر مي‌گيرد: Of عبارت Case; دستور 1 : مقدار 1; دستور 2 : مقدار 2 ; دستور 3 : مقدار3 . . . Otherwise ; دستورEnd ; { End of case } 165

اسلاید 166: مثال : برنامه‌اي بنويسيد که دو عدد به همراه يک عملگر را از ورودي دريافت کرده، کار يک ماشين حساب ساده را شبيه‌سازي نمايد.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 }166

اسلاید 167: دياگرام دستور Case بصورت زير مي‌باشد: CaseعبارتثابتofدستوراتEnd;:,167

اسلاید 168: ساختارهاي کنترلي بسياري از مواقع لازم است عمل يا اعمال به تعداد دفعات معين يا نامعين انجام شوند. در چنين مواقعي زبانهاي برنامه‌نويسي دستوراتي دارند که مي‌توان اين اعمال تکراري را انجام داد. در حالت کلي ساختارهاي کنترلي شامل يک يا چند شرط و همچنين متغير يا اصطلاحاً شمارنده‌اي براي پايان دادن به شرط مي‌باشند 168

اسلاید 169: شکل کلي حلقه بصورت زير مي‌باشد: Do مقدار نهايي To مقدار اوليه =: انديس For ; دستوربايد توجه داشته باشيد که در حلقه تعداد تکرار کاملاً مشخص است و حلقه دقيقاً به تعداد تکرار مشخص اجرا مي‌شود.169

اسلاید 170: حلقه for اين دستور براي انجام عمل يا اعمالي مشخص به تعداد تکرار معين بکار برده مي‌شود. حلقه for شامل يک انديس ( index ) مقدار اوليه ( initial value ) مقدار نهايي ( final value ) و مقدار افزاينده مي‌باشد. اين حلقه با قرار دادن مقدار اوليه در انديس حلقه شروع شده و بعد از هر تکرار يک واحد به انديس حلقه اضافه مي‌کند تا در نهايت به مقدار نهايي برسد. شکل کلي حلقه بصورت زير مي‌باشد:170

اسلاید 171: 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 عدد را محاسبه و چاپ نمايد. 171

اسلاید 172: دستور for را بصورت زير هم مي‌توان بکار برد.do مقدار نهايي downto مقدار اوليه = : انديس for ; دستوردر اين شکل از دستور For ابتدا مقدار اوليه در انديس حلقه قرار داده مي شود و بعد از آن در هر تکرار حلقه يک واحد از انديس حلقه کم مي شود تا به مقدار نهايي برسد .172

اسلاید 173: مثال : برنامه‌اي بنويسيد که عدد صحيحي را از ورودي دريافت کرده و فاکتوريل آن را محاسبه نمايد.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 .173گروه آموزشی مهندسی ایران Iranian Engineering Group WWW.MOHANDE30.COM

اسلاید 174: do مقدار نهايي to مقدار اوليه = : انديس1 for do مقدار نهايي to مقدار اوليه = : انديس for 2 ; دستور هاي متداخل For 174گروه آموزشی مهندسی ایران Iranian Engineering Group WWW.MOHANDE30.COM

اسلاید 175: 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 )175

اسلاید 176: دياگرام دستور for Forانديسdoمقدار اوليه:=مقدار نهاييDowntoدستورTo 176

اسلاید 177: حلقه While در حالت کلي هدف از بکار بردن اين دستور انجام عملياتي مشخص به تعداد دفعات نامعين است :اين حلقه به صورت زير بکار برده مي شود Do عبارت منطقي While ; دستور177

اسلاید 178: 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 }مثال : بزرگترين مقسوم عليه دو عدد178

اسلاید 179: دياگرام دستور While بصورت زير مي باشد:Whileعبارت شرطيdoدستورBeginدستورEnd;و در صورتي که دستور مرکب باشد دياگرام بصورت زیر است : 179

اسلاید 180: دستور Repeat اين دستور نيز از نوع دستورات تکراري مي‌باشد و به کمک آن مي‌توان يک يا چند دستور را به تعداد نامعين بار اجرا کرد. while اين دستور مشابه دستوراست، با تفاوتهايي که در زير عنوان مي‌کنيم:While برعکس دستور Repeat 1) در دستورشرط حلقه در انتهاي حلقه بررسي مي‌شود لذا حلقه حداقل يکبار اجرا مي‌شود. 180

اسلاید 181: 2) دستور Repeate تا زماني اجرا مي‌شود که شرط خاصي تحقق پيدا نکرده است در حاليکه دستور While تا زماني که شرط برقرار باشد، اجرا مي‌شود.3) دستور Repeat نياز به بلوک ندارد و همراه Until ظاهر مي‌شود.181

اسلاید 182: شکل کلي اين دستور بصورت زير مي‌باشد: Repeat ; دستور1; دستور2 ..; شرط يا شروط until182

اسلاید 183: 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 }برنامه‌ مجموع و ميانگين تعدادي عدد صحيح مثبت183

اسلاید 184: دياگرام دستور Repeat بصورت زير مي‌باشد: Repeatدستور;Untilشرط يا شروط184

اسلاید 185: معرفي چند پروسيجر ( Procedure ) پروسيجرها يا زير روال‌ها قسمت‌هاي مستقلي از برنامه اصلي مي‌باشند که به تنهايي اعمال خاصي را انجام داده و وظايف مستقل و بخصوصي بر عهده آنها گذاشته مي‌شود. يک مزيت بزرگ پروسيجرها اينست که يکبار در برنامه گنجانده شده ولي در محلهاي مختلف ازآن استفاده به عمل مي‌آيد و از اصول برنامه‌نويسي ساخت يافته‌است. 185

اسلاید 186: پروسيجر Exit هدف: انتقال کنترل برنامه به خارج از بلوک فعليProcedure Exit ; استفاده از اين پروسيجر در هر بلوک از برنامه باعث مي‌شود که کنترل برنامه بلافاصله به خارج از آن بلوک انتقال يابد. 186

اسلاید 187: پروسيجر Break هدف: خاتمه دادن به اجراي يک حلقه Procedure Break ; استفاده از پروسيجر فوق باعث مي‌شود که اجراي يک حلقه خاتمه يافته و کنترل برنامه به دستورالعمل بعدي انتقال يابد. 187

اسلاید 188: پروسيجر continue هدف: بازگشت به ابتداي حلقه Procedure continue ; وقتي اين پروسيجر در حلقه ظاهر مي‌شود کنترل برنامه به اول حلقه انتقال مي‌يابد و دستورات بعد از پروسيجر اجرا نمي‌شوند.188

اسلاید 189: ارائه چند مثال از کاربرد حلقه ها و شرط‌ها مثال : برنامه‌اي بنويسيد که يک عدد صحيح در مبناي ده را از ورودي دريافت کرده، به يک عدد در مبناي 2 ببرد. 189

اسلاید 190: 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 } 190

اسلاید 191: 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 جمله سري زير که به سري فيبوناچي معروف است را چاپ نمايد. 191

اسلاید 192: تمرينات 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- خروجي قطعه برنامه‌هاي زير را تعيين کنيد: 192

اسلاید 193: 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 ; 193

اسلاید 194: تمرينات برنامه نویسی 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 194

اسلاید 195: 2- برنامه‌اي بنويسيد که تعدادي عدد از ورودي دريافت کرده مجموع ارقام هر عدد را در خروجي چاپ نمايد. ( پايان داده ها به 1- ختم مي شود ) 3- برنامه‌اي بنويسيد که دو عدد صحيح را از ورودي دريافت کرده سپس:اعداد فيبوناچي بين اين دو عدد را چاپ کند.4- برنامه‌اي بنويسيد که يک اسکناس 1000 توماني را به حالتهاي مختلف يعني به اسکناس 200 توماني، 100 توماني، 50 توماني، 20 توماني، 10 توماني و سکه هاي 5 توماني و 2 توماني و يک توماني خرد نمايد.195

اسلاید 196: فصل 8Arrayآرایه ها هدفهاي كليشناخت انواع آرايه‌ها و موارد استفاده از آنهاشناخت لزوم استفاده از ساختار داده اي به نام آرايه ‌ شناخت مفاهيم مرتب‌سازي و جستجوشناخت الگوريتمهاي مرتب‌سازي و جستجو196

اسلاید 197: ÷ هدفهاي رفتاري آرايه‌ها يك بعدي را در برنامه‌هاي خود بكار ببرد. ماتريسها را پياده‌سازي نمايد. عمل جستجو در آرايه انجام دهد.يك ليست را توسط روشهاي مرتب سازي حبابی، انتخابي و غيره مرتب كند.دانشجو پس از مطالعه اين فصل بايد بتواند:197

اسلاید 198: آرايه و انواع آن خانه‌هاي پشت سرهم از حافظه که همنوع بوده و توسط يک اسم معرفي مي‌شوند، آرايه نام دارد. نحوه دسترسي به هر يک از اعضاء آرايه از طريق انديس آرايه امکان‌پذير است.براي تعريف آرايه ابتدا طول آرايه که درحقيقت تعداد خانه‌هاي آنرا مشخص مي‌کند، معين مي‌گردد. سپس نوع خانه‌هايي که داده‌ها در آن قرار خواهند گرفت را تعيين مي کنند 198

اسلاید 199: آرايه‌هاي يک بعدي آرايه‌هاي يک بعدي بصورت زير تعريف مي‌شوند: Name : array [ 1 . . Length ] of type ; نوع آرايه کلمه ذخيره شده طول آرايه کلمه ذخيره شده اسم آرايه 199

اسلاید 200: برای مثال : Var No: Array [ 1.. 50 ] of integer ; id: Array [ 1.. 20 ] of Byte ; Name , Fam: Array [ 1.. 30 ] of char ;200

اسلاید 201: مقداردهي آرايه‌ها مثل متغيرها به دو صورت امکان‌پذير است :1- با استفاده از دستورات ورودي2- مقداردهي در طول برنامهطريقه دسترسي به عناصر آرايه بصورت زير مي‌باشد: Name [ index ] انديس آرايه اسم آرايه 201

اسلاید 202: مثال : برنامه‌اي بنويسيد که 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 }202

اسلاید 203: مثال: برنامه‌اي بنويسيد که يک آرايه 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 . 203

اسلاید 204: آرايه‌هاي دو بعدي براي نمايش ماتريس درحافظه معمولاً از آرايه‌هايي بنام آرايه‌هاي دوبعدي استفاده مي‌کنند براي درک بيشتر اين آرايه‌ها آنها را بصورت ماتريس در نظر مي‌گيرند. آرايه‌هاي دو بعدي بصورت زير معرفي مي‌شوند: Name : array [ 1 .. row , 1 .. column ] of type ; نوع عناصر آرايه کلمه ذخيره شده تعداد ستونها تعداد سطرها کلمه ذخيره شده اسم آرايه204

اسلاید 205: مثال : برنامه‌اي بنويسيد که يک ماتريس 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. 205

اسلاید 206: آرايه‌هاي چند بعدي مي‌توان آرايه‌هايي با ابعاد بيشتر از دو نيز تعريف کرد. بطور کلي براي معرفي يک آرايه چند بعدي مي توان بصورت زيرعمل کرد :Name : array [ 1.. length1 ] of array [ 1.. length2 ] …. Of array [ 1.. lengthN ] of Type و ياName: array [ 1.. length1 , 1.. length2 , …. 1.. lengthN ] of Type206

اسلاید 207: نکاتي چند در مورد آرايه‌ها تعريف آرايه با محدوده منفي براي مثال: A: array [ -10.. 10 ] of Real ; تعريف آرايه از نوع منطقي ( Boolean ) براي مثال: A: array [1.. 20 ] of Boolean ;207

اسلاید 208: آرايه‌هاي با محدوده منطقي: براي مثال A: array [ Boolean ] of integer;آرايه‌اي با محدوده کاراکتري: براي مثال A: array [ A.. Z ] of Real ;آرايه‌اي که براي اعضاي آن محدوديت قائل شويم براي مثال: A: array [ 1.. 20 ] of 1.. 30 208

اسلاید 209: جستجو و مرتب‌سازي ( Search and Sort ) يکي از مسائلي که در بحث طراحي الگوريتم بسيار مهم است، بحث مرتب‌سازي و جستجو مي باشد. منظور از جستجو اينست که يک مقداري را از يک ليست جستجو کنيم و منظور از مرتب سازي اينست که يک ليست مرتب از داده ها را ايجاد کنيم. حال تعدادی الگوريتم که براي مرتب‌سازي و جستجو بکار مي‌روند. را بررسي مي‌کنيم بخصوص زمانيکه ساختار داده ما يک آرايه باشد209

اسلاید 210: جستجو در آرايه در کل دو نوع عمل جستجو را در اين کتاب بررسي مي‌کنيم :جستجوي خطي Linear search جستجو دودويي Binary search 210

اسلاید 211: جستجوي خطي Linear search در جستجوي خطي عبارت مورد جستجو را نخست با اولين عضو آرايه مقايسه مي‌کنيم، اگر برابر بود عمل جستجو با موفقيت همراه بوده و عمل جستجو خاتمه مي‌يابد در غير اينصورت روند را ادامه داده و عبارت مورد جستجو را بترتيب با عضو دوم، سوم ... مقايسه مي‌کنيم تا اينکه حالت تساوي حاصل شود و اگر اين حالت حاصل نشد، عباريت مورد جستجو در ليست قرار ندارد.211

اسلاید 212: قطعه برنامه زير را مي توان در حالت کلي براي جستجوي خطي بکار برد: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 ) ;212

اسلاید 213: جستجو دودويي Binary search درجستجوي دودوئي ليست اوليه بايدمرتب باشد. براي جستجو در چنين آرايه‌اي نخست انديس وسط آرايه را پيدا مي‌کنيم و عنصر واقع در اين انديس را با عبارت مورد جستجو مقايسه مي‌کنيم و حالات زير ممکن است حاصل شود:(Low انديس ابتداي آرايه ‌و upper انديس آخرين عناصرآرايه و middle انديس عنصر وسط مي‌باشد.) 213

اسلاید 214: if A [ middle ] < X Then حالت اول : در اينصورت Low : = middle و مقدار جديد middle را که عبارتست از:Middle : = ( low + middle ) / 2 214

اسلاید 215: if A [ middle ] < X Then حالت دوم : در اينصورت upper : = middle و مقدار جديد middle را که عبارتست از:Middle : = ( low + middle ) / 2 215

اسلاید 216: if A [ middle ] = X Then حالت سوم : در اينصورت Write ( The Eiement is found ) Low < upper در صورتي که حالت‌هاي الف يا ب اتفاق بيفتد، عمل جستجو را تا زمانيکهمي باشد ادامه مي‌دهيم و در هر مرحله که حالت سوم رخ دهد عمل جستجو خاتمه مي‌يابد.216

اسلاید 217: مرتب‌سازي براي مرتب‌سازي داده‌ها روشهاي متفاوتي وجود دارد . تفاوت روشهاي مرتب‌‌سازي در زمان اجراي آنها مي باشد. در حالت کلي با توجه به تعداد وروديها (داده ها) و نوع مسئله مرتب‌سازي مي توان از انواع روش‌هاي مرتب‌سازي استفاده نمود.حال بعضي از روش هاي مرتب سازي عمومي را بررسي مي‌کنيم. مرتب‌سازي حبابي ( Bubble sort ) مرتب‌سازي انتخابي ( Selection sort )217گروه آموزشی مهندسی ایران Iranian Engineering Group WWW.MOHANDE30.COM

اسلاید 218: مرتب‌سازي حبابي ( Bubble sort ) ساده‌ترين روش مرتب‌سازي روش مرتب‌سازي حبابي مي‌باشد. يکي از خصوصيات بارز اين نوع مرتب‌سازي اين است که فهم آن ساده بوده و برنامه‌نويسي آن به سهولت انجام مي گيرد.مرتب‌سازي حبابي نخست عنصر اول و دوم را با هم مقايسه مي‌کند و در صورت نياز، آنها را جابجا مي‌کند، سپس عنصر دوم و سوم را مقايسه مي‌کند. اين عمل را تا زمانيکه به انتهاي آرايه نرسيده تکرار مي‌کند، در پايان مرحله اول بزرگترين عنصر در آخرين خانه آرايه قرار مي‌گيرد. در مرحله دوم از خانه اول تا خانه N – 1 عمل بالا را انجام مي‌دهد. اين روند را تا زمانيکه تمام عناصر آرايه مرتب نشده‌اند ادامه مي‌دهد و در نهايت يک ليست مرتب شده بصورت صعودي در خروجي توليد مي‌شود. 218گروه آموزشی مهندسی ایران Iranian Engineering Group WWW.MOHANDE30.COM

اسلاید 219: 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)/2219گروه آموزشی مهندسی ایران Iranian Engineering Group WWW.MOHANDE30.COM

اسلاید 220: مرتب‌سازي انتخابي ( Selection sort )در اين روش مرتب‌سازي نخست کوچکترين عنصر را در کل آرايه پيدا کرده در خانه اول آرايه قرار مي‌دهيم سپس عنصر کوچکتر بعدي را يافته در خانه دوم قرار مي‌دهيم اين روند را تا زمانيکه کل آرايه مرتب نشده ادامه مي‌دهيم220

اسلاید 221: 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 }قطعه برنامه‌اي که براي مرتب‌سازي انتخابي مي‌توان نوشت بصورت زير مي‌باشد:221

اسلاید 222: چند مثال در مورد آرايه‌ها مثال : برنامه‌اي بنويسيد که يک عدد صحيح از ورودي دريافت کرده سپس اعداد اول قبل از آن را توليد و در آرايه قرار دهد.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 ; 222

اسلاید 223: 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 }223

اسلاید 224: مثال : برنامه‌اي بنويسيد که يک ماتريس 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 }224

اسلاید 225: مثال : برنامه‌اي بنويسيد که از ادغام دو آرايه مرتب ،آرايه سومي بنام 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 ] ) ; 225

اسلاید 226: 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 }226

اسلاید 227: 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 }227

اسلاید 228: مثال : برنامه ای بنويسيد که يک جمله حداکثر 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 } 228

اسلاید 229: تمرينات - کداميک از دستورات زير در مورد اعلان زير صحيح است: الف- a [ A ]: = Z ب- a [ a ]: = A ج- a [ A ]: = 1 د- a [ I ]: = 12 ح- a [ i ]: = 12 a: array [ A .. Z ] of char 229

اسلاید 230: 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 - تعداد بايتهايي که هر کدام از اعلانهاي زير اشغال مي کنند را محاسبه نمائيد.230

اسلاید 231: تمرينات برنامه‌نويسی برنامه‌اي بنويسيد که که يک آرايه حداکثر 50 عنصري را از ورودي دريافت کرده و سپس عناصري از آرايه که اول هستند را با صفر جايگزين کرده آرايه حاصل را در خروجي چاپ کند.برنامه‌اي بنويسيد که عددي از ورودي دريافت کرده سپس آن را به عامل هاي اول تجزيه نمايد و حاصل را بصورت زير در خروجي چاپ نمايد:براي مثال: 21 = ( 3 ^ 1 ) * ( 7 ^ 1 ) 231

اسلاید 232: برنامه‌اي بنويسيد که يک عدد از ورودي دريافت کرده سپس در صورت وجود صفرهاي آن را حذف نموده، نتيجه را در خروجي چاپ نمايد.برنامه اي بنويسد که يک ماتريس 5 * 5 را از ورودي دريافت کرده سپس مجموع هر سطر را انتهاي همان سطر و مجموع هر ستون را در انتهاي همان ستون چاپ نمايد.232

اسلاید 233: برنامه‌اي بنويسيد که يک ماتريس حداکثر 10 * 10 را از ورودي دريافت کرده ماتريس هم بر حسب ستون و هم بر حسب سطر مرتب نموده به همراه ماتريس اوليه در يک سطر چاپ نمايد.برنامه‌اي بنويسيد که يک آرايه 200 عنصري ازنوع صحيح که 150 عنصرمرتب درآن قرار مي‌گيرد را از ورودي دريافت کرده سپس آرايه دومي با 50 عنصر را از ورودي بخواند.233

اسلاید 234: فصل 9هاي كتابخانه ای‌ توابع و روال‌هدفهاي كليشناخت توابع و روالهاي استاندارد براي نوعهاي صحيحشناخت ساختار تابع و روال شناخت توابع و روالهاي استاندارد براي نوعهاي اعشاري و كاركتريشناخت توابع و روالهاي استاندارد رياضي234

اسلاید 235: ÷ هدفهاي رفتاري توابع و روالهاي استاندارد را در صورت نياز در برنامه استفاده كند. ساختار توابع و خروجيهاي آنها را تشخيص داده و در برنامه خود از آنها استفاده كند. ساختار روالها و خروجيهاي آنها را تشخيص داده و نتايج حاصل از آنها را مورد استفاده قرار دهد.توابع رياضي را براي محاسبه عبارت رياضي در برنامه بكار ببرد.دانشجو پس از مطالعه اين فصل بايد بتواند:235

اسلاید 236: ساختار تابع در کل هدف تابع اينست که متغير يا متغيرهايي را بعنوان پارامتر از برنامه اصلي دريافت کرد. عمل خاصي را روي پارامترها انجام داده و نتيجه را به برنامه اصلي برگرداند. شکل کلي فراخواني توابع در برنامه اصلي بصورت زير مي‌باشد:ساختار تابع: Function Name ( parameters ) : Type نوع تابع پارامترها اسم تابع کلمه ذخيره شده236

اسلاید 237: توابعي براي اعداد صحيح و اعشاري تابع Abs هدف: باز گرداندن قدر مطلق ( absolute ) پارامتري که به آن ارسال مي‌شود: Function Abs ( x: Integer ): Integer ; Function Abs ( x: Real ): Real ; اين تابع يک عبارت از نوع حقيقي يا صحيح را بعنوان آراگون دريافت کرده سپس قدر مطلق آن را محاسبه و حاصل را برگرداند.237

اسلاید 238: مثال : 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 238

اسلاید 239: تابع Sin هدف: باز گرداندن سينوس يک عدد از نوع اعشاري شکل تابع: Function Sin ( X: Real ): Real ; X يک عبارت يا عدد از نوع اعشاري بوده و حاصل مقدار سينوس X مي‌باشد.239

اسلاید 240: مثال : Var X : Real ; Begin X : = sin ( 10 ) ; Write ( sin ( 10 ) = , x :8 : 2 ) ;End.240

اسلاید 241: تابع Cos هدف: باز گرداندن کسينوس يک عدد از نوع اعشاري.شکل تابع: Function cos ( X: Real ): Real ; X يک عبارت با عدد از نوع اعشاري بوده و حاصل مقدار کسينوس X مي‌باشد.241

اسلاید 242: Var X : Real ; Begin X : = cos ( 10 ) ; Write ( cos ( 10 ) = , x : 8 : 2 ) ;End . مثال : 242گروه آموزشی مهندسی ایران Iranian Engineering Group WWW.MOHANDE30.COM

اسلاید 243: تابع ArcTanهدف: بازگرداندن آرک تانژانت يک عدد از نوع اعشاريشکل تابع: Function ArcTan ( X: Real ): Real ; X يک عبارت يا عدد از نوع اعشاري بوده حاصل مقدار آرک تانژانت X مي‌باشد.243گروه آموزشی مهندسی ایران Iranian Engineering Group WWW.MOHANDE30.COM

اسلاید 244: Var X : Real ; Begin X : = ArcTan ( 10 ) ; Write ( ArcTan ( 10 ) = , x : 8 : 2 ) ;End . توجه: در صورتي که در توابع مثلثاتي زاویه از نوع درجه ارائه شود مي‌توان با فرمول زير معادل راديان آن را محاسبه کرد: Real = Dey * 3.14159 / 180 244گروه آموزشی مهندسی ایران Iranian Engineering Group WWW.MOHANDE30.COM

اسلاید 245: تابع Exp هدف: عدد نپر ( e = 2.71828 … ) را به توان يک عدد مي‌رساند.شکل تابع: Function Exp ( X: Real ): Real ; X عبارت يا متغيري از نوع اعشاري بوده و حاصل تابع نيز يک عدد اعشاري مي‌باشد اين تابع مقدار eبه توان X را محاسبه مي‌کند.245گروه آموزشی مهندسی ایران Iranian Engineering Group WWW.MOHANDE30.COM

اسلاید 246: Var X : Real ; i : integer ; Begin For i : = 1 to 10 do Begin X : = exp ( i ) ; Writeln ( x : 8 : 2 ) ; End ;End . مثال : 246

اسلاید 247: تابع frac هدف: قسمت اعشاري يک عدد اعشاري را برمي‌گرداند.شکل تابع: Function frac ( X: Real ): Real ; X عددي از نوع اعشاري و حاصل تابع يک عدد اعشاري که قسمت اعشاريعدد X است مي باشد و بعبارت ديگر اين تابع قسمت اعشاري عدد ورودي را به عنوان خروجي باز مي‌گرداند.247

اسلاید 248: 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 248

اسلاید 249: تابع Int هدف: قسمت صحيح يک عدد اعشاري را برمي‌گرداند.شکل تابع: Function Int ( X: Real ): Real ; X يک عبارت يا متغير از نوع اعشاري و خروجي تابع فيزيک عدد اعشاري است اين تابع مقدار صحيح يک عدد اعشاري در خروجي نشان مي‌دهد. 249

اسلاید 250: Var y , x : Real ; Begin X : = Int ( 2.87 ) ; { 2.0 } Y : = Int ( - 8.76 ) ; { - 8.0 } End . مثال : 250

اسلاید 251: تابع Lnهدف: محاسبه لگاريتم يک عدد اعشاري در مبناي e.شکل تابع: Function Ln ( X: Real ): Real ; X يک عبارت يا متغير ازنوع اعشاري بوده وحاصل تابع فيزيک عدداعشاري مي‌باشد.251

اسلاید 252: Var X : Real ; Begin X : = Ln ( 2.87 ) ; { x = 3.73767 } Write ( x = , x : 10 : 5 ) ; End . مثال : 252

اسلاید 253: تابع Odd هدف: فرد بودن عدد صحيح را بررسي مي کند.شکل تابع: Function odd ( X: logint ): Booleam ; X يک عبارت از نوع longint است و تابع ،فرد بودن عبارت را بررسي مي کند اگر مقدار خروجي تابع True باشد X فرد است و اگر مقدار خروجي تابع False باشد X فرد نيست. 253

اسلاید 254: Var i : integer ; Begin For i : = 1 to 100 do If odd ( i ) Then Writeln ( i = , j : 3 ) ; End . مثال : 254

اسلاید 255: تابع Ord هدف: غالباً براي پيدا کردن کد اسکي يک متغير کاراکتري بکار مي‌رود.شکل تابع: Function Ord ( x: char ): Longint ; عبارت x از نوع کارکتري را بعنوان پارامتر دريافت و کد اسکي آن را برمي گرداند. اگر x از نوع اسکالر باشد تابع بعنوان خروجي ترتيب قرار گرفتن x را در مجموعه اي که ابتدا به عنوان اسکالر اعلان شده، باز مي‌گرداند.255

اسلاید 256: Var ch : char ; Begin For ch : = A to Z do Write ( ord ( ch ) : 5 ) ; End .مثال : کد اسکي A تا Z را درخروجي چاپ مي‌کند کد اسکي A عدد 65 مي‌باشد.خروجی :256

اسلاید 257: تابع pi هدف: عدد پي را بر مي‌گرداند.شکل تابع: Function pi: Real ; اين تابع براي بازگرداندن عددي پي ( 3.141592 … ) مورد استفاده قرار مي‌گيرد.257

اسلاید 258: تابع Pred هدف: مقدار قبل مقدار پارامتر را بر مي گرداند.پارامتر تابع مي تواند از هر نوع باشد و با توجه به نوع پارامتر تابع نياز از هم نوع مي‌باشد و خروجي تابع مقدار قبل از x مي‌باشد.Function pred ( x ): < same type of parameter > ; شکل تابع: 258

اسلاید 259: Ch: = pred ( d ) ; { ch = c }i: = pred ( 15 ) ; { i = 14 }flag: = pred ( True ) ; { flag = false } i: = pred ( - 30 ) ; { i = - 31 } مثال : 259

اسلاید 260: تابع Random هدف: براي توليد عدد تصادفي شکل تابع: Function Random: Real ; Function Random ( x: word ): word ; اگر تابع Random به شکل يک يعني بدون آرگومان مورد استفاده قرار گيرد يک عدد تساوي از نوع اعشاري بين صفر و يک توليد مي کند و اگر به شکل دو بکار رود باعث توليد يک عدد تصادفي از نوع word که بزرگتر يا مساوي صفر و کوچکتر از x است خواهد شد.260

اسلاید 261: 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 توليد نمايد. 261

اسلاید 262: تابع Round هدف: براي گرد کردن اعداد اعشاري بکار مي رود.شکل تابع: Function Round ( x: Real ): Longint ; X يک عبارت يامتغير اعشاري بوده وخروجي تابع يک عدد ازنوع Longint مي‌باشد که نتيجه گرد کردنX مي‌باشد. اين تابع X را به نزديکترين مقدارصحيح گرد مي‌کند. 262

اسلاید 263: 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 } مثال : 263

اسلاید 264: تابع sqr هدف: براي محاسبه مجذور يک عدد صحيح يا اعشاري بکار مي‌رود.شکل تابع: Function sqr ( x: Integer ): Integer ; Function sqr ( x: Real ): Real ; X عبارتي يا متغييري از نوع صحيح يا اعشاري بوده و خروجي تابع فيزيک يک عدد صحيح يا اعشاري مي باشد اين تابع مجذور X را بعنوان خروجي بر مي‌گرداند.264

اسلاید 265: Var i : integer ; Begin For i : = 1 to 10 do Writeln ( I ^ 2 = , sqr ( I ) ) ; End . مثال : 265

اسلاید 266: تابع sqrt هدف: براي محاسبه جذر يک عدد بکار ميرود.شکل تابع: Function sqrt ( x: Real ): Real ;X يک عبارت از نوع اعشاري بوده و خروجي تابع فيزيک عدد اعشاري مي‌باشد اين تابع جذر X را بعنوان خروجي بر مي‌گرداند.266

اسلاید 267: 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 .مثال : 267

اسلاید 268: تابع succ هدف: مقدار بعد از مقدار فعلي را برمي گرداند.شکل تابع: Function succ ( x ): same type of parameters ; X يک عبارت از نوع صحيح، اولين و غيره بوده و خروجي تابع نيز از همان نوع X مي باشد اين تابع مقدار بعد از X را بعنوان خروجي بر مي‌گرداند.268

اسلاید 269: ch : = suce ( a ) { ch = b } ch : = suce ( A ) { ch = B } i : = suce ( 15 ) { i = 16 } flag : = suce ( false ) { flag = True }flag : = suce ( True ) { تعريف نشده } مثال : 269

اسلاید 270: تابع Trunc هدف: قسمت صحيح يک عدد اعشار را بر مي‌گرداند. شکل تابع: Function Trunc ( x: Real ): Longint ;X يک عبارت يا متغير از نوع اعشاري بوده و خروجي تابع يک عدد از نوع Longint مي‌باشد. اين تابع قسمت صحيح عدد اعشاري X را بعنوان خروجي بر مي‌گرداند.270

اسلاید 271: 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 . مثال : 271

اسلاید 272: توابع از نوع کاراکتري در اين بخش توابعي را بررسي مي کنيم که خروجي آنها از نوع کاراکتري باشد. تابع chr هدف: معادل کاراکتري يک کد اسکي را بر مي‌گرداند.شکل تابع: Function chr ( X: Byte ): char ; X يک عبارت يا متغير از نوع بايت بوده و خروجي تابع يک کارکتر مي‌باشد. اين تابع کد اسکي را دريافت کرده و معادل کارکتري آن را بر مي‌گرداند.272

اسلاید 273: Var i : Byte ; Begin For i : = 65 to 91 do Writeln ( chr ( I ) ) ; End . مثال : خروجی :برنامه بالا حروف A تا Z را در خروجي چاپ مي‌کند.273

اسلاید 274: تابع Upcase هدف: براي تبديل يک کاراکتر به حرف بزرگتر بکار مي‌رود.شکل تابع: Function Upcase ( ch: char ): char ; ch يک عبارت يا متغير از نوع کاراکتر بوده و خروجي تابع فيزيک کاراکتري باشد اين تابع حرف کوچک را به حرف بزرگ تبديل کرده و بعنوان خروجي حروف بزرگ را بر مي‌گرداند.274

اسلاید 275: مثال : 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 } 275

اسلاید 276: روال‌هاي استاندارد در بخش هاي قبل ديديد که در توابع پارامترها به تابع ارسال مي شود و تابع نيز مقداري را بعنوان خروجي برمي‌گرداند روالها نيز مشابه توابع عمل مي‌کنند با اين تفاوت که خروجي روالها از طريق پارامتر برمي‌گردانده مي‌شود يا اعلان به سيستم عامل مي‌باشد. بنابراين روالها بدون نوع هستند. شکل کلي روال‌ها بصورت زير مي‌باشد:Procedure Name ( Parameturs ) ; پارامترهاي روال اسم روال کلمه ذخيره شده276

اسلاید 277: روال Dec هدف: يک يا چند واحد از پارامتر ارسالي کم مي کند.شکل روال: Procedure Dec ( Var X: longint ) ; Procedure Dec ( Var X: longint , N: longint ) ;X يک متغير از نوع longint و بصورت متغيري مي‌باشد اين روال يک واحد از پارامتر ارسالي کم مي‌کند.277

اسلاید 278: Var N : integer Begin N : = 1201 ; Dec ( N ) ; { N = 1200 } Writeln ( N ) ; Dec ( N , 200 ) ; { W = 1000 } Writeln ( N ) ; End .مثال : 278

اسلاید 279: روال Exit هدف: کنترل برنامه را به خارج از بلوک جاري منتقل مي کند.شکل روال: Procedure Exit ; اين روال باعث مي شود که کنترل برنامه از بلوک جاري خارج شود. اگر اين روال در برنامه اصلي بکار رود باعث خروج از برنامه مي‌شود. و اگر در يک روال يا تابع بکار رود باعث خروج از روال يا تابع شده و کنترل برنامه به برنامه اصلي منتقل مي‌شود.279

اسلاید 280: Var i , j : integer ;Begin i : = 100 ; j : = 20 ; Dec ( i , j ) ; Write ( i ) ; Exit ;End . مثال : خروجی :بعد از اتمام عمليات تابع Exit باعث خروج از برنامه مي شود.280

اسلاید 281: روال Halt هدف: خاتمه دادن به اجراي برنامه شکل روال: Procedure Halt ; اين روال باعث خاتمه اجراي برنامه شده و کنترل برنامه به سيستم عامل بر مي‌گردد.281

اسلاید 282: روال Inc هدف: اضافه کردن يک يا چند واحد به يک متغير شکل تابع:X يک عبارت يا متغير از نوع Longint مي باشد اين روال به مقدار متغير x يک يا چند واحد اضافه مي‌کند.Procedure Inc ( Var X: longint ) Procedure Inc ( Var X: longint , N: longint ) ; 282گروه آموزشی مهندسی ایران Iranian Engineering Group WWW.MOHANDE30.COM

اسلاید 283: 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 .مثال : 283گروه آموزشی مهندسی ایران Iranian Engineering Group WWW.MOHANDE30.COM

اسلاید 284: روال Randomize هدف: باعث تغير نحوه توليد اعداد تصادفي مي شود.شکل روال: Procedure Randomize ; وقتي در برنامه از تابع Random استفاده مي‌کنيم اعداد تصادفي توليد شده در اجراهاي مختلف يکسان مي باشد براي جلوگيري از اين وضعيت قبل از استفاده از تابع Random روال Rondomize را بکار مي‌بريم. تا باعث توليد اعداد تصادفي متفاوت در اجراهاي مختلف گردد.284

اسلاید 285: Var i : word ;Begin Randomize; For i : = 1 to 10 do Writeln ( Random ( 50 ) ) ; End .مثال : 285گروه آموزشی مهندسی ایران Iranian Engineering Group WWW.MOHANDE30.COM

اسلاید 286: حل چند مثال برنامه‌نويسي مثال : برنامه اي بنويسيد که يک ماتريس مربع ( 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 ] ) ; 286

اسلاید 287: 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 } 287

اسلاید 288: مثال : برنامه‌اي بنويسيد که يک جمله از ورودي دريافت کرده سپس حروف بزرگ جمله را به حروف کوچک تبديل نمائيد.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 } 288

اسلاید 289: تمرينات خروجي تمرينات زير را تعيين کنيد: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 . 289

اسلاید 290: .2خروجي دستورات زير را محاسبه نمائيد:a) Ch: = A ; Ch: = chr ( ord ( ch ) + 3 ) ; Write ( ch ) ; b) X: = 12 ; Succ ( x ) ; Ch: = B ; Pred ( ch ) ; Write ( x , ch ) ; 290

اسلاید 291: تمرينات برنامه‌نويسي 1- برنامه‌اي بنويسيد که تعداد 1000 شماره حساب بانکي 7 رقمي بطور تصادفي بين 5119432 و 9981711 را توليد کرده و چاپ کند.2- برنامه اي بنويسيد تا تعداد 38 عدد تصادفي صحيح بين 10 تا 99 راتوليد کرده، سپس آن را در خروجي به شکل مربع وسط صفحه نمايش چاپ کند.3- برنامه‌اي بنويسيد که يک عدد 20 رقمي از ورودي دريافت کرده آن را در يک عدد تک رقمي ضرب نموده و حاصل را در خروجي چاپ نمائيد.291

اسلاید 292: فصل 10(String) متغيرهاي كاراكتري و رشته‌هاهدفهاي كلي بررسي ساختار آرايه هايي از نوع كاراكتر ‌معرفي نوع دادة جديد به نام رشتهمقايسه آرايه اي از كاراكتر و رشته ‌شناخت توابع و روالهاي استاندارد براي رشته ها ‌292

اسلاید 293: ÷ هدفهاي رفتاري آرايه‌اي از كاراكترها را در برنامه بكار ببرد. آرايه‌اي از كاراكترها را با رشته مقايسه كند. اسمي افراد و غيره را با استفاده از آرايه‌اي از رشته مرتب نمايد. توابع و روالهاي استاندارد مربوط به رشته‌ها را در برنامه خود بكار ببرد.دانشجو پس از مطالعه اين فصل بايد بتواند:293

اسلاید 294: متغيرهايي از نوع کاراکتر متغيرهاي کاراکتري ظرفيت پذيرش يک کاراکتر ( شامل يک رقم، يک حرف از حروف و يا يک کاراکتر ديگر ) را دارا مي‌باشند.: مقدار دهي اين متغير ها به صورت زير مي‌باشدch: = A ; اگر بخواهيم متغير هاي کاراکتري را از ورودي بخوانيم بايد دقت بيشتري به .خرج دهيم براي اينکه فضاهاي خالي کاراکتر محسوب مي شوند294

اسلاید 295: مثال : خروجي قطعه برنامه زير را تعيين کنيد. Ch: = A ;C: = a ;If ch = c Then Writeln ( equal ) Else Writeln ( Not equal ) ;خروجي حاصل از قطعه برنامه بالا بصورت زير است: Not equal295

اسلاید 296: درکل مي‌توان کاراکترها را از لحاظ اردينال (مرتبه) بصورت زير دسته‌بندي کرد: 1- رقم ها بصورت زير مقايسه مي‌شوند: 0 < 1 < 2 < 3 < … < 9 رقم‌ها از لحاظ کد اسکي پشت سر هم قرار گرفته‌اند. 2- حروف بصورت زير مقايسه مي شوند: A < B < … < Z < … < a < b < … < z 296

اسلاید 297: متغيرهاي رشته‌اي ( String ) تعريف: مجموعه‌اي از کاراکتر را يک رشته ناميده و متغير از نوع آن را يک متغير رشته‌اي مي‌نامند.اين متغير نيز مانند ساير متغيرها در قسمت تعاريف متغيرها ( Var ) معرفي مي‌شود. در تعريف يک متغير رشته‌اي معمولاً طول آن را مشخص مي‌کنند. اگر طول تعيين نشود بطور قراردادي کامپايلر حداکثر طول را براي آن در نظر مي‌گيرد. حداکثر طول رشته 255 کاراکتر مي‌باشد.297

اسلاید 298: نحوه تعريف متغير رشته اي بصورت زير مي‌باشد: Name : string [ length ] طول رشته کلمه ذخيره شده اسم رشته 298

اسلاید 299: متغيرهاي رشته‌اي را بصورت زير مي‌توان مقداردهي کرد: Var S : string [ 10 ] ; . . .Begin . . S : = pascal ; Write ( s ) ; . . End .299

اسلاید 300: براي خواندن متغيرهاي‌رشته‌اي ازدستورRead يا Readln بصورت زيرمي‌توان‌استفاده‌ کرد:Read ( s ) ; هنگام خواندن متغيرهاي رشته‌اي اگر طول رشته ورودي از طول تعريف شده بيشتر باشد فقط به اندازه طول تعريف شده خوانده مي شود و اگر طول رشته ورودي کمتر از طول تعريف شده باشد، رشته ورودي در منتهي‌اليه سمت چپ متغير رشته‌اي قرار گرفته و بقيه متغير رشته اي بدون محتوا باقي مي ماند، 300

اسلاید 301: براي چاپ يک متغير رشته‌اي نيز ازدستور Write يا Writeln مي‌توان استفاده کرد: Write ( s ) ;مثال : برنامه‌اي بنويسيد که شماره دانشجوئي، اسم و فاميل دانشجوئي را از ورودي دريافت کرده سپس در خروجي نمايش دهد.301

اسلاید 302: 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. 302

اسلاید 303: آرايه‌اي از رشته بصورت زير تعريف مي‌شود: Name : Array [ 1 .. length ] of string نوع رشته اي طول آرايه اسم آرايه 303

اسلاید 304: براي خواندن چنين آرايه‌اي بصورت زير عمل مي‌کنيم:For i : = 1 to 50 do Readln ( Name [ i ] ) ; براي نمايش آرايه در خروجي بصورت:For i: = 1 to 50 do Writeln ( Name [ i ] ) 304

اسلاید 305: مثال : برنامه‌اي بنويسيد که اسم 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 }305

اسلاید 306: مثال : برنامه‌اي بنويسيد که اسم، فاميلي و شماره دانشجوئي حداکثر 50 دانشجو را از ورودي دريافت نمايد.سپس با خواندن اسمي از ورودي، ساير اطلاعات اسم خوانده شده را در صورت وجود در خروجي نمايش دهد.Var Name , Family : array [ 1 .. 50 ] of string [ 30 ] ; id : array [ 1 .. 50 ] of longint ; Nam : string [ 30 ] ; 306

اسلاید 307: 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 ;307

اسلاید 308: 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 } 308

اسلاید 309: توابع و روالهاي کتابخانه‌اي براي متغيرهاي رشته‌اي تابع Concat هدف: الحاق دو يا چند رشته به يکديگر شکل تابع: Function concat ( S1 , S2 , … , Sn ): string ; Sn , … , S2 , S1 متغيرهايي از نوع رشته هستند و خروجي تابع نيز يک متغير رشته‌اي است اين تابع دويا چندتابع را به هم پيوند داده، و رشته حاصل را برمي‌گرداند.309

اسلاید 310: : مثال Var Str3 , str1 , str2 : string Begin Str1 : = Pascal ; Str2 : = Book ; Str3 : = Concat ( Str1 , Str2 ) ; write ( Str3 ) ; End.با اجراي برنامه فوق، عبارت Pascal Book نشان داده خواهد شد.310

اسلاید 311: تابع Copy هدف: استخراج يک زير رشته ( substring ) از يک رشته شکل‌تابع:Function copy (S:string ; Index:Integer; count: Integer): string; S يک عبارت يا متغير رشته اي که مي خواهيم از آن زير رشته اي که نقطه شروع آن Index و طول آن Count مي باشد جدا کنيم. لذا زير رشته حاصل، يک رشته که طول آن به اندازه Count است، مي‌باشد.311

اسلاید 312: : مثال Var Str , str1: string ; Begin Str: = Pascal Book ; Str1: = Copy ( Str , 7 , 4 ) ; { Str1 = Book } write ( Str1 ) ; End. 312

اسلاید 313: روال Delete هدف: حذف يک زير رشته از يک رشته شکل‌روال:Procedure delete (Var str: string; Index:integer;length: integer ) ; Str يک متغر رشته اي، Index يک عبارت يا متغير صحيح و Length نيز يک عبارت يا متغير صحيح مي‌باشد. روال Delete يک زير رشته را از يک رشته حذف مي‌کند اين روال از محل Index بطول Length از رشته Str حذف مي‌کند و رشته حاصل بعنوان خروجي روال برگردانده مي‌شود.313

اسلاید 314: : مثال Var St : string ; Begin St: = Pascal.Book ; Delete ( St , 7 , 5 ) ; writeln ( St ) ; End. خروجي حاصل از برنامه فوق Pascal مي‌باشد.314

اسلاید 315: روال Insert هدف: درج ( وارد کردن ) يک رشته در يک رشته ديگر شکل روال: Procedure Insert ( Str1: string ;Var Str2: string ; Index: Byte ) ; Str1 عبارت يا متغير رشته اي، Str2 متغير رشته اي و Index عبارتي عدد از نوع صحيح مي‌باشد. روال Insert ، رشته Str1 رادر رشته Str2 از خانه Index درج مي‌کند و رشته حاصل خروجي روال خواهد بود. 315

اسلاید 316: : مثال Var Str1 , str2: string ; Begin Str1: = Pascal 7 ; Str2: = Turbo ; Insert ( Str1 , Str2 , 6 ) ; End. خروجي حاصل از برنامه بالا Turbo pascal 7 خواهد بود.316

اسلاید 317: تابع Length هدف: محاسبه طول رشته شکل تابع: Function length ( Str: string ): Integer ; Str يک عبارت رشته اي بوده و خروجي تابع يک عدد صحيح مي‌باشد. اين تابع طول رشته ورودي را محاسبه و بعنوان خروجي بر مي‌گرداند.317

اسلاید 318: : مثال Var St: string ; n: integer ; Begin St: = Turbo Pascal 7 ; n: = length ( S4 ) ; { n = 14 } Write ( The length of string is: , n ) ; End. 318

اسلاید 319: تابع Pos هدف: براي جستجوي يک رشته داخل رشته ديگر شکل تابع: Function pos ( Str1: string ; Str2: string ): Byte ; Str1 يک عبارت يا متغير رشته اي و Str2 نيز يک عبارت يا متغير رشته اي مي‌باشد و خروجي تابع يک عدد صحيح مي باشد. اين تابع محل اولين وقوع رشته Str1 در رشته Str2 را بعنوان خروجي بر مي‌گرداند.319

اسلاید 320: : مثال Var Str1 , Str2: string ; i: integer ; Begin Str1: = Book ; Str2: = Pascal Book ; i: = Pos ( Str1 , Str2 ) ; { i = 8 } Write ( i = , i ) ; End. نکته: توجه کنيد که اگر عمل جستجو با موفقيت انجام نشود ( يعني رشته اول در رشته دوم وجود نداشته باشد ) تابع مقدار صفر بر مي‌گرداند.320

اسلاید 321: روال Str هدف: براي تبديل عدد به يک رشته عددي بکار مي رود.درشکل 1، I يک عبارت يا متغيرعددي بوده و Str يک متغير رشته‌اي مي‌باشد اين روال يک عدد صحيح با فرمت مشخص را به يک رشته عددي تبديل مي کند.درشکل 2 ، F يک عبارت يا متغير رشته‌اي و Str يک متغير رشته‌اي مي‌باشد.شکل روال: 1: Procedure Str( I: integer: format , Str: string ) ; 2: Procedure Str ( F: Real: format , Str: string ) ; 321

اسلاید 322: : مثال 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. 322

اسلاید 323: روال 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 ) ;323

اسلاید 324: : مثال 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. 324

اسلاید 325: ارائه چند مثال در مورد رشته‌ها و کاراکترها مثال : برنامه‌اي بنويسيد که يک جمله از ورودي دريافت کرده سپس در صورتي که کلمه IS وجود داشته باشد آنها را به are تبديل نمايد و در نهايت رشته حاصل را در خروجي نمايش دهد.توجه کنيد که ممکن است بيش از يک بار کلمه IS تکرار شده باشد در اينصورت همه کلمات IS را با are تبديل کند. 325

اسلاید 326: 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 } 326

اسلاید 327: مثال : برنامه‌اي بنويسيد که يک رشته از ورودي دريافت کرده، سپس معکوس رشته را بدست آورده بهمراه خود رشته در دو سطر جداگانه چاپ نمايد. 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 } 327

اسلاید 328: تمرينات با فرض اينکه 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 ) ) ; 328

اسلاید 329: خروجي قطعه برنامه زير را تعيين کنيد: Var S1: string ; i: integer ;Begin S1: = ABCDEF ; For i: = 1 to length ( S1 ) ; Delete ( S1 , i , 1 ) ; Writeln ( S1 ) ;.End 329

اسلاید 330: خروجي قطعه برنامه زير را تعيين کنيد: 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 ) ;.End330

اسلاید 331: 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 هستند خروجي عبارت زير را تعيين کنيد.331

اسلاید 332: تمرينات برنامه‌نويسی برنامه‌اي بنويسيد که يک پاراگراف را از ورودي دريافت کرده ( حداکثر 10 خط ) سپس:الف) تعداد کلمات هر سطر را شمرده و انتهاي سطر نمايش دهد.ب) تعداد حروف صدا دار را شمرده چاپ نمايد.ج) تعداد خطوط برنامه را شمرده در خروجي چاپ کند.د) تعداد جملات هر خط را محاسبه و در سطر هاي جداگانه نمايش دهد.332

اسلاید 333: برنامه‌اي بنويسيد که يک عدد در مبناي مشخص را از ورودي دريافت کرده سپس آن را به مبناي m که از ورودي خوانده مي شود ببرد.برنامه‌اي بنويسيد که يک پاراگراف را از ورودي دريافت کرده کلمات تکراري هر سطر را حذف نموده و پاراگراف حاصل را بهمراه پاراگراف اوليه در خروجي با پيغام مناسب نمايش دهد.333گروه آموزشی مهندسی ایران Iranian Engineering Group WWW.MOHANDE30.COM

اسلاید 334: برنامه‌اي بنويسيد که دو عدد 20 رقمي ( بصورت رشته بايد خوانده شود ) را از ورودي دريافت کرده سپس مجموع و حاصل ضرب اين دو عدد را محاسبه و در خروجي با پيغام مناسب چاپ نمايد.برنامه‌اي بنويسيد که يک رشته از ورودي دريافت کرده سپس کلمات داخل آن را بصورت عمودي کاراکتر به کاراکتر نمايش دهد:برنامه‌اي بنويسيد که يک پاراگراف با حداکثر 5 خط را از ورودي دريافت نمايد. سپس مجموع ارقام يا اعداد ( در صورت وجود ) هر خط را محاسبه نموده در انتهاي همان سطر نمايش دهد.334گروه آموزشی مهندسی ایران Iranian Engineering Group WWW.MOHANDE30.COM

اسلاید 335: فصل 11برنامه‌هاي فرعيهدفهاي كلي شناخت اجزاء تشكيل‌دهنده توابع و روالها ‌ بررسي انواع پارامترها و متغيرها در برنامه‌هاي فرعي شناخت تفاوتهاي روالها و توابع معرفي مزاياي استفاده از زير برنامه‌ها335گروه آموزشی مهندسی ایران Iranian Engineering Group WWW.MOHANDE30.COM

اسلاید 336: ÷ هدفهاي رفتاري برنامه خود را به چندين زيربرنامه تقسيم‌بندي نمايد. زيربرنامه‌ها را با توجه به قوانين موجود، در ساختار برنامه جا دهد. باتوجه به مزاياي استفاده از آنها را در برنامه خود بكار ببرد. دانشجو پس از مطالعه اين فصل بايد بتواند:336

اسلاید 337: روال‌ها روال‌ها نوعي از برنامه‌هاي فرعي هستند، که به طور مستقل و جداگانه وظيفه يا وظايف خاصي از برنامه اصلي را انجام مي‌دهند. روال ها در صورت نياز اطلاعات خود را از طريق پارامترها دريافت و همچنين در صورت نياز نتايج را از طريق پارامترها به برنامه اصلي باز مي‌گردانند. پارامترها در حقيقت خطوط ارتباطي بين برنامه اصلي و برنامه‌هاي فرعي هستند. پارامترها باعث مي شوند، که توابع و روال ها روانتر عمل کنند، زيرا آنها به برنامه هاي فرعي اين قابليت را مي دهند که با هر فراخواني، داده‌هاي مختلفي را مورد پردازش قرار دهند.337

اسلاید 338: شکل کلي روال‌ها بصورت زير مي باشد: Procedure Name ( parameters list ) ; ليست پارامترها اسم روال کلمه ذخيره شدهVar { List of locad variable }Begin . . { Procedure Body } . .End ; { End of procedure }338

اسلاید 339: در حالت کلي روال ها در برنامه اصلي بصورت زير ظاهر مي‌شوند:; اسم برنامه اصلي Program ; تعاريف برنامه اصلي Procedure ..... ; Begin { main program } . . . فراخواني روال ها . .End. { End of program }339

اسلاید 340: پارامترها با توجه به محل وقوع آنها به دو دسته تقسيم مي شوند:پارامترهاي صوري ( Formal parameters ) .2پارامترهاي واقعي ( Actual parameters ) از پارامترهاي صوري هنگام اعلان روال و از پارامترهاي واقعي هنگام . فراخواني روال ها استفاده مي‌شود340

اسلاید 341: پارامترهاي صوري در حالت کلي 2 نوعند، که با توجه به نوع روال و تصميم برنامه نويس مورد استفاده قرار مي گيرند: پارامترهاي مقداري ( Value parameters ) پارامترهاي متغيري ( Variable parameters ) 341

اسلاید 342: پارامترهاي مقداري ( Value parameters ) پارامترهاي مقداري، پارامترهايي هستند که مقدار متغيرهاي فرستاده شده از برنامه اصلي را دريافت مي کنند و وظيفه آنها فقط عبور دادن مقدار به روال مي‌باشد. لذا تغیيرات پارامترهاي مقداري در روال به برنامه اصلي انتقال نمي‌يابد: پارامترهاي مقداري بصورت زير تعريف مي شوندProcedure Name ( var1 : type ; var2 : type , . . . . ) ; ليست پارامترهاي از نوع مقداري اسم روال کلمه ذخيره شده 342

اسلاید 343: مثال : به برنامه زير توجه کنيد: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 }343

اسلاید 344: نکته: پارامترهايي که در روال بکار برده مي شود، هيچ ارتباطي به پارامترهاي ارسالي از برنامه اصلي ندارند و فقط مقادير اين متغيرها از برنامه اصلي ارسال مي شود. لذا اسامي پارامترهاي صوري ممکن است هم اسم با پارامترهاي واقعي برنامه اصلي انتخاب شوند، اين به معناي اين نيست که اين پارامترها ( پارامترهاي صوري ) همان پارامترهاي واقعي هستند.در مثال بالا اين تناظر برقرار است:پارامترهاي واقعي متناظر است با پارامترهاي صوريX1 A1X2 A2Y1 B1Y2 B2344

اسلاید 345: متغيرهاي … , Var2 , Var1 پارامترهاي مقداري هستند. توجه کنيد، که اين پارامترها صوري هستند و نوع و ترتيب آنها بايد با نوع و ترتيب پارامترهاي واقعي در تناظر يک به يک باشند.345

اسلاید 346: مثال : به برنامه زير توجه کنيد: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 }346

اسلاید 347: همانطور که ملاحظه مي کنيد، روالي بنام test با 4 پارامتر مقداري در برنامه استفاده شده است. متغيرهاي y2 , y1 , x2 , x1 از برنامه اصلي به روال test ارسال شده و بترتيب مقادير اين متغيرها در متغيرهاي با همان نوع در B2 , B1 , A2 , A1 قرار مي گيرند.347

اسلاید 348: پارامترهاي متغيري ( Variable parameters ) يك پارامتر متغيري، تغييرات يك پارامتر واقعي را بعنوان خروجي به برنامه اصلي برمي‌گرداند. تفاوت اين گونه پارامترها با پارامترهاي مقداري در ارسال تغييرات ايجاد شده در پارامترها مي‌باشد. وقتي نياز است، كه نتايج روال به برنامه اصلي برگردد، از پارامترهاي متغيري استفاده مي‌كنند. اعلان پارامترهاي متغيري به صورت زير مي‌باشد: procedure Name ( var id1 : type ; var id2 : type , … ); ليست پارامترهاي متغيري اسم رواال كلمه ذخيره شده متغيرهاي id1 , id2 و … پارامترهاي متغيري مي‌باشند كه نتايج روال، توسط آنها به برنامه اصلي بازگردانده مي‌شود.348

اسلاید 349: مثال : روالي بنام 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 }349

اسلاید 350: پارامترهاي واقعي و صوري عبارتند از:پارامتر واقعي متناظر است با پارامترهاي صوريNum1 Num1Num2 Num2Total sumAverage aveNum1 , Num2 پارامترهاي مقداري و sum , ave پارامترهاي متغيري مي‌باشند، كه توسط آنها نتايج به برنامه اصلي برگردانده مي‌شود.350

اسلاید 351: متغيرهاي محلي و سراسري ( Local and Global Variable) در برنامه‌هاي فرعي دو نوع متغير علاوه از پارامترها مورد استفاده قرار مي‌گيرند. اين متغيرها متغيرهاي محلي يا متغيرهاي سراسر هستند.متغيرهاي محلي، متغيرهايي هستند كه در بلاك مربوط به خود قابل استفاده هستند. ولي متغيرهاي سراسري در تمام برنامه‌هاي فرعي قابل دسترس مي‌باشند.متغيرهاي محلي در داخل برنامه‌هاي فرعي در قسمت تعاريف معرفي مي‌شوند و در خارج از روال قابل دسترسي نيستند.351

اسلاید 352: مثال : روالي براي محاسبه مجموع و ميانگين دو عدد بنويسيد.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} 352

اسلاید 353: در مثال بالا sum , Ave متغيرهاي محلي مي‌باشند. براي فراخواني روال CalcSumAve(x.y); كه درآن x.y دو متغير ازنوع Real مي‌باشند. به شكل زيرتوجه‌كنيد:پارامترهاي واقعيX Y پارامترهاي صوريNum1 Num2 متغيرهاي محلي Sum Ave 353

اسلاید 354: مثال : خروجي برنامه زير را تعيين كنيد.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=5354

اسلاید 355: روال‌ها معمولاً به سه شكل ظاهر مي‌شوند: بكارگيري روال‌هاي بدون پارامتر بكارگيري روال همراه پارامترهاي با خاصيت ورودي بكارگيري روال همراه پارامترهاي با خاصيت ورودي و خروجي 355

اسلاید 356: بكارگيري روال‌هاي بدون پارامترگاهي لازم است تا برنامه فرعي كاملاً مستقل (بي‌نياز از مقادير برنامه اصلي) در بخش‌هاي مختلف يك برنامه اجرا شود. در اين صورت نياز به استفاده از پارامتر بي‌مفهوم مي‌باشد و از روالهاي بدون پارامتر استفاده مي‌كنند.غالباً زمانيكه بخواهيم پيغام‌هاي خاصي را در قسمتهاي مختلف برنامه نمايش دهيم، اين پيغام‌ها را در يك روال قرار داده و در صورت نياز، روالمربوطه را فراخواني مي‌كنيم.356

اسلاید 357: مثال : روال Head بدون دريافت پارامتري فراخواني مي‌شود.Program Example ;Procedure Head ; Begin WriteL(Name Family Age No); WriteLe(……………………………...); End;Begin{Main} WriteLn( open university ) ; Head;End.357

اسلاید 358: بكارگيري روال همراه پارامترهاي با خاصيت ورودي همانطور كه قبلاً اشاره كرديم، هدف از بكارگيري پارامترها انتقال مقادير از برنامه اصلي به روال‌ها مي‌باشد. اگر اين انتقال يك طرفه باشد يعني فقط از برنامه اصلي به روال باشد، اين نوع پارامترها فقط خاصيت ورودي خواهند داشت. (قبلا در اين مورد توضيح داده شده است) در اين نوع روال‌ها از پارامترهاي مقداري استفاده مي‌كنند.358

اسلاید 359: مثال : روالي بنويسيد كه توسط آن مربعات اعداد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}359

اسلاید 360: بكارگيري روال همراه پارامترهاي با خاصيت ورودي و خروجي در اين نوع روال‌ها پارامترها دو خاصيت مهم دارند يكي انتقال داده‌ها از برنامه اصلي به روال و ديگري انتقال يا ارجاع نتايج از روال به برنامه‌اصلي مي‌باشد. در اين نوع روال‌ها از پارامترهاي متغيري استفاده مي‌كنند.360

اسلاید 361: مثال : روالي بنام change بنويسيد كه توسط آن دوعدد بعنوان پارامتر دريافت كرده، مقادير اين دو متغير را جابجا نموده و نتيجه را در برنامه اصلي چاپ نمايد.Program Example ;Var A , b: integer ;Procedure change (var x , y: integer) ;var temp:integer;Begin Temp:=x; X:=y; Y:=temp;End;361

اسلاید 362: Begin { Main } ReadLn( a , b ) ; Change( a , b ); WriteLn ( a= , a , b= , b ) ;End.{End of program}362گروه آموزشی مهندسی ایران Iranian Engineering Group WWW.MOHANDE30.COM

اسلاید 363: ارتباط روال‌ها با يكديگر در پاسكال زير برنامه‌‌ها نه تنها از طريق برنامه اصلي بلكه از داخل يكديگر نيز .فراخواني مي‌شوندفراخواني روال‌ها از داخل يكديگر تابع قوانين كلي زير است: قانون اول قانون دوم قانون سوم 363گروه آموزشی مهندسی ایران Iranian Engineering Group WWW.MOHANDE30.COM

اسلاید 364: قانون اول از هر برنامه (اصلي يا فرعي) به برنامه فرعي در صورتي مي‌توان، دسترسي داشت، كه در بخش تعاريف آن برنامه (اصلي يا فرعي) قرار داشته باشد. بطور مثال در شكل زير برنامه اصلي M مي‌تواند، به كليه برنامه‌هاي فرعي p1,p2 و… كه در بخش تعاريف برنامه اصلي قرار دارند، مراجعه كند364گروه آموزشی مهندسی ایران Iranian Engineering Group WWW.MOHANDE30.COM

اسلاید 365: Main . . . .Proc1Proc2ProcN برنامه اصليبرنامه هاي فرعي365

اسلاید 366: مثال : به برنامه زير توجه كنيد:program Main;var ……..procedure proc1;var ……..Begin ………End;Procedure proc2;Var ………Begin ……end;Begin {Main} Proc1; Proc2;End. 366

اسلاید 367: روال‌هاي proc1 , proc2 داخل برنامه اصلي Main تعريف شده‌اند. لذا براحتي مي‌توان در برنامه اصلي به آنها دسترسي پيدا كرد. روال‌ها خود نيز داخل هم مي‌توانند قرار بگيرند. دقيقاً مثل روال‌هاي معمولي با اين تفاوت كه در داخل روال بايد تعريف شوند. به اينگونه روالها، اصطلاحاً روال‌هاي متداخل يا تودرتو مي‌گويند. 367

اسلاید 368: اگر روال‌ها در بخش تعاريف يك برنامه به موازات يكديگر تعريف شوند و نه در داخل هم، در روال‌هاي بعدي امكان رجوع به روال‌هاي قبلي وجود خواهد داشت. بعبارت ديگر به روالي مي‌توان دسترسي پيدا كرد كه قبلاً تعريف شده باشد. قانون دوم 368

اسلاید 369: بطور مثال اگرp1,p2,p3 سه روال باشند دراينصورت مي‌توان بصورت زيرعمل كرد: Main P1P2P3 P2روال هابرنامه اصليدر شكل بالا چون p2 قبلاً معرفي شده است مي‌توان آنرا داخل p3 فراخواني كرد.369

اسلاید 370: اگر روال‌ها در بخش تعاريف برنامه‌أي بصورت متداخل باشند، در اينصورت از روال دروني مي‌توان به روال‌هاي بيروني كه قبلاً تعريف شده‌، مراجعه كرد و همچنين از روال دروني به روال‌هاي بيروني كه به موازات يكديگر قرار گرفته‌اند، نيز مي‌توان دسترسي پيدا كرد. بطور مثال در شكل زير روال p1 مي‌تواند به روال‌هاي p2,p3 دسترسي پيدا كند. وهمچنين روال دروني p4 مي‌تواند به‌روال‌هاي p2 , p3 مراجعه كند. قانون سوم 370

اسلاید 371: Main P3P2P1روال هابرنامه اصلي371

اسلاید 372: اعلان روال‌ها به روش forward همانطور كه قبلاً اشاره كرديم از روالي مي‌توان در روال ديگر استفاده كرد، كه قبلاً تعريف شده باشد. در توربوپاسكال نقيصه فوق به كمك اعلان forward قابل حل است. بدين صورت كه اگر روالي به هنگام تعريف با اعلان forward همراه باشد، بدون رعايت از پيش تعريف شدن مي‌تواند، در روالهاي ديگر ظاهر شود.372

اسلاید 373: شكل اعلان به روش forward بصورت زير مي‌باشد:Procedure Name ( parameters ) ; forward ; كلمه ذخيره شده ليست پارامترها اسم روال كلمه ذخيره شده373

اسلاید 374: مثال :Program forward_Main ;Var ………Procedure proc3 ; forward ;Procedure proc1;var ……..Begin ………end;Procedure proc2;var ………Begin ……… proc3; ……end;374

اسلاید 375: Procedure proc3;var ……..Begin …….End;Begin {Main program} ……… proc1; proc2; proc3; ………End. {End of program}همانطور كه ملاحظه مي‌كنيد با اعلان روال proc3 بصورت forward، بقيه روالها مي‌توانند به آن دسترسي پيدا كنند.375

اسلاید 376: توابع (Functions) نوع ديگري از برنامه‌هاي فرعي، توابع مي‌باشند. توابع مانند روال‌ها، پيمانه‌هاي مستقلي هستند. با اين تفاوت كه روال‌ها مي‌توانند، تعدادي خروجي داشته باشند، در حالي که توابع فقط يك خروجي دارند. در روال‌ها معمولاً خروجي‌ها توسط پارامتر به برنامه‌ اصلي ارجاع داده مي‌شود. ولي در توابع اينكار به نحو ديگر انجام مي‌گيرد.376

اسلاید 377: شكل كلي اعلان يك تابع بصورت زير مي‌باشد: Function Name ( List Of Parameters ) : Function Type ; نوع تابع ليست پارامترها اسم تابع کلمه ذخيره شده 377

اسلاید 378: تابع فقط مي‌تواند، يك خروجي داشته باشد. نوع خروجي تابع، همان نوع تابع محسوب مي‌شود. لذا با توجه به نوع خروجي تابع، نوع تابع تشخيص داده مي‌شود. ذكر اين نكته خالي از لطف نيست كه، نوع پارامترهاي صوري توابع معمولاً مقداري هستند چرا كه توابع نوعي برنامه‌هاي فرعي هستند كه فقط يك خروجي برمي‌گردانند. لذا استفاده از پارامترهاي از نوع متغيري پسنديده نمي‌باشد. (اشكال كامپايلري در توربوپاسكال ندارد ولي در پاسكال استاندارد اين كار اشكال كامپايلري دارد.)نکته :مقدار خروجي توابع توسط اسم تابع برگردانده مي‌شود. توابع مثل روالها بعد از قسمت تعاريف برنامه اصلي ظاهر مي‌شود. 378

اسلاید 379: شكل كلي توابع بصورت زير مي‌باشد: Function Name ( Parameters ) : Type ;Var ………..Begin …………….. …………….. …………….. Name := Resualt Of Function ;End ;379

اسلاید 380: توجه به نكات زير در بكارگيري توابع ضروري بنظر مي‌رسد:تمام پارامترهاي تابع بايد از نوع مقداري باشند.نوع داده نتيجه تابع در انتهاي عنوان تابع و بعد از ليست پارامترهاي صوريقرار مي‌گيرد.در بدنه تابع، خروجي تابع با نسبت دادن مقدار به نام تابع مشخص مي‌شود.380

اسلاید 381: مثال : برنامه‌أي بنويسيد كه يك عدد از ورودي دريافت كرده سپس توسط تابعي بنام 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.381

اسلاید 382: ناحيه داده‌ها بعد از فراخواني بشكل زير مي‌باشد: پارامترهاي واقعيN نتيجه تابعپارامترهاي صوريMمتغيرهاي محليPIنتيجه تابع?? ناحيه داده هاي Fact ناحيه داده هاي اصلي382

اسلاید 383: توابع بازگشتي (Recursion Functions) در پاسكال يك تابع يا روال مي‌تواند، خودش را فراخواني نمايد. پيمانه‌اي كه خودش را فراخواني مي‌كند يك پيمانه بازگشتي نام دارد. اين نوع توابع در بدنه خود، خودشان را فراخواني مي‌كنند. اين فراخواني تا برقراري يك شرط خاص كه غالباً به يك عدد ثابت ختم مي‌شود، ادامه پيدا مي‌كند. سپس مقدار تابع از پايين به بالا محاسبه مي‌شود و در نهايت نتيجه تابع حاصل مي‌شود.383

اسلاید 384: هنگامي كه تابع بازگشتي به خود مراجعه مي‌كند، مقادير فعلي متغيرهاي خود را در محلي از حافظه بنام پشته (stack) قرار مي‌دهد، اگر بازگشت به تابع بازگشتي مجدداً صورت گيرد، مقادير فعلي متغيرها مجدداً بدنبال مقادير قبلي و اصطلاحاً در پشت مقادير اوليه قرار مي‌گيرند. هنگامي كه شرط پاياني در تابع بازگشتي رخ مي دهد، در اولين بازگشت مقاديري را كه هنگام مراجعه به خود، در پشته نگهداري كرده، مجدداً در دسترس قرار مي‌دهد و بهمين ترتيب در بازگشت‌هاي بعدي اين عمل تكرار مي‌شود تا مقدار تابع محاسبه شود. 384

اسلاید 385: شكل زير نحوه قرار گفتن مراجعه‌هاي يك تابع بازگشتي به پشته را نمايش مي‌دهد.مقادير متغيرها درآخرين بازگشت به تابع.....مقادير متغيرها در سومين بازگشت به تابعمقادير متغيرها در دومين بازگشت به تابعمقادير متغيرها در اولين بازگشت به تابعشرط پاياني385

اسلاید 386: ترتيب دسترسي به مقادير هنگام بازگشت از تابع بازگشتي از بالا به پايين مي‌باشد و مي‌توان آنرا بصورت زير نمايش داد:مقادير متغيرها درآخرين بازگشت به تابع.....مقادير متغيرها در سومين بازگشت به تابعمقادير متغيرها در دومين بازگشت به تابعمقادير متغيرها در اولين بازگشت به تابع386

اسلاید 387: مثال : برنامه‌أي بنويسيد كه با استفاده از توابع بازگشتي فاكتوريل عدد صحيح 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}. End387

اسلاید 388: Fact := 12 * Fact ( 1 )3 * Fact ( 2 )4 * Fact ( 3 )5 * Fact ( 4 )N = 1 N = 5 در برنامه بالا ترتيب قرار گرفتن مقادير در پشته بصورت زير مي‌باشد:388

اسلاید 389: مثال : تابعي براي محاسبه بزرگترين مقسوم عليه مشترك دو عدد صحيح 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 ; 389

اسلاید 390: مقايسه توابع و روال‌ها توابع و روال‌ها هر دو برنامه‌هاي فرعي هستند، كه بطور مستقل وظايفي را بر عهده دارند. ولي در اين ميان از بعضي جنبه‌ها متفاوت مي‌باشند كه عبارتند از: 1. نحوه فراخواني آنها با هم متفاوت است. روال‌ها از طريق عبارات روال فراخوانده مي‌شوند، درصورتي كه فراخواني تابع توسط عبارات مقايسه‌أي و يا تخصيص نتيجه به يك متغير صورت مي‌گيرد.2. هنگام اعلان يك تابع، نوع تابع يا نوع نتيجه حاصل از تابع بايد ذكر شود، در صورتي كه روال‌ها نيازي به اين كار ندارند.3. توابع فقط يك خروجي برمي‌گردانند، ولي روال‌ها مي‌توانند، چندين خروجيبرگردانند. درضمن نتيجه توابع توسط اسم تابع فرستاده مي‌شود ولي روال‌ها از طريق پارامترها، نتايج را برمي‌گردانند.390

اسلاید 391: طريقه ارسال آرايه‌ها به توابع و روال‌ها آرايه‌ها خود مجموعه‌أي از داده‌ها مي‌باشند، لذا براي ارسال آنها نمي‌توانيم از روش معمولي ارسال پارامترها استفاده كنيم. و بطور مستقيم نمي‌توان آنها را به برنامه‌هاي فرعي انتقال داد. براي ارسال آرايه‌ها به عنوان پارامتر به برنامه‌هاي فرعي از دستور Type استفاده مي‌كنند. دستور Type قبل از تعاريف برنامه اصلي بكار مي‌رود و توسط اين دستور در واقع يك نوع ساده‌سازي در تعاريف فراهم مي‌شود. و با اين ساده‌سازي مي‌توان داده‌هاي ساخت يافته را به برنامه‌هاي فرعي منتقل كرد.391

اسلاید 392: فرم كلي دستور Type در بخش تعاريف بصورت زير است: تعريف داده ساخت يافته = شناسه Type براي مثال يك ارايه از نوع صحيح را تعريف مي‌كنيم:Type No = array [1…100] of integer ; در اينصورت تعريف آرايه به، No نسبت داده مي‌شود. اگر بخواهيم متغيري از نوع آرايه بالا تعريف كنيم، آنرا از نوع No تعريف مي‌كنيم:Var Number: No ;392

اسلاید 393: مثال : برنامه‌اي بنويسيد كه يك آرايه حداكثر 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 ; 393

اسلاید 394: While ( I <= N ) And ( flag ) do Begin If b[ I ] = x Then Begin Index:= I ; Flag:= FALSE ; End ; Inc ( I ) ; End ; Search:= Index ; End ; {*********************************************}394

اسلاید 395: 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 }395

اسلاید 396: تمرينات روال Down را در نظر بگيريد:Procedure Down ( N: Integer ) ;Begin While N > 0 do Begin Write ( N: 3 ) ; Dec ( N ) ; End ;End ;الف) وقتي روال بصورت down (5) فراخواني شود، چه چيزي چاپ مي‌شود. ب) مقدار پارامتر واقعي N بعد از اجراي روال چيست؟396

اسلاید 397: تابع بازگشتي زير را در نظر بگيريد: 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 فراخواني كنيد.397

اسلاید 398: تمرينات برنامه‌نويسي برنامه‌اي بنويسيد كه اطلاعات حداكثر 100 دانشجو كه عبارتند از: Name اسم Family فاميلي St_No شماره دانشجوئيرا از ورودي دريافت كرده سپس:الف) توسط روالي بنام sort اطلاعات را برحسب شماره دانشجوئي مرتب كند.ب) توسط تابعي بنام search شماره دانشجوئي فردي را از ورودي دريافت نمايد، در صورتي كه شخص موردنظر در ليست باشد، ساير اطلاعات آنرا نمايش دهد.398

اسلاید 399: آرايه‌‌أي از نوع صحيح با حداكثر 100 عنصر را در نظر بگيريد. برنامه‌أي بنويسيد كه ابتدا آرايه را از ورودي دريافت كرده سپس با استفاده از يك تابع بازگشتي بيشترين مقدار آرايه را محاسبه نمايد. دو آرايه مرتب حداكثر100 عنصري‌ كه شامل اسامي افراد مي‌باشد را درنظر بگيريد. برنامه‌اي بنويسيد كه نخست دو آرايه را از ورودي دريافت نموده سپس توسط روالي بنام merge اين دو آرايه در هم ادغام نموده و در آرايه سومي قرار دهد.399

اسلاید 400: فصل 12مجموعه‌ها و داده‌هاي شمارشيهدفهاي كلي مفهوم مجموعه و داده‌هاي شمارشي در زبان پاسكال‌ مجموعه و داده‌هاي شمارشي به عنوان متغير استفاده از مجموعه‌ها و داده‌هاي شمارشي در برنامه 400

اسلاید 401: ÷ هدفهاي رفتاري مفهوم مجموعه و داده‌هاي شمارشي را درك كند. بتواند در صورت لزوم از مجموعه و داده‌هاي شمارشي استفاده كند.دانشجو پس از مطالعه اين فصل بايد بتواند:401گروه آموزشی مهندسی ایران Iranian Engineering Group WWW.MOHANDE30.COM

اسلاید 402: تعداد محدودي از داده‌ها كه از نظر نوع يكسان هستند، در غالب مجموعه و يا گونه‌هاي شمارشي نگهداري مي‌شوند كه مفهومي ‌شبيه در رياضيات دارند. براي استفاده در مواردي خاص نظير روزهاي هفته و يا نوع ماشينها و... كه ترتيبي هستند و يا يك مجموعه از داده‌هاي پشت سر هم مي‌باشند، استفاده از اين ساختارها كار را بسيار راحت مي‌كند. هر چند وجود آنها به عنوان ساختار‌هاي داده‌اي، الزامي‌نيست. بهرحال به عنوان ابزارهايي از زبان پاسكال هستند كه در مواقعي، ضروري بنظر مي‌رسند و مسئله را به صورتي قابل‌فهم و راحت حل مي‌كند.مقدمه402گروه آموزشی مهندسی ایران Iranian Engineering Group WWW.MOHANDE30.COM

اسلاید 403: مجموعه‌ها (Sets) در زبان پاسكال مجموعه، مفهومي ‌شبيه به مفهوم مجموعه در رياضيات جديد دارد. متغيري است كه شامل ليستي از اعداد صحيح، كاراكتر، بولين و يا از نوع شمارشي مي‌باشد كه داراي تعداد عناصر محدود به حداكثر 256 تا مي‌باشد. از اين جهت بسيار شبيه به يك آرايه در زبان پاسكال است كه شامل داده‌هايي از يك نوع مي‌باشد، ولي آرايه داراي عناصر محدودي نيست و در ضمن مانند آرايه تعريف نمي‌شود.403

اسلاید 404: تعريف مجموعه‌براي تعريف يك مجموعه از كلمات كليدي set of بصورت زیر استفاده مي‌كنيم: TypeName= Set of Type Of Set; Type Digit_type = 0..9; Digit = Set of Digit_type مثلا : 404

اسلاید 405: 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;مثال :405

اسلاید 406: عمليات روي مجموعه‌ها در رياضيات عمل عضويت وجود دارد كه به اين معني است كه متغيري عضو مجموعه مي‌باشد يا خير. اين عمل در زبان پاسكال با كلمه كليدي in صورت مي‌گيرد. اگر عضويت صحيح باشد جواب True وگرنه False‌ مي‌باشد. همچنين دو مجموعه را مي‌توان با علامات شرطي =، <>، <= و >= مقايسه كرد كه همگي داراي خروجي درست يا غلط مي‌باشند. ولي‌علامات شرطي < و > در مورد مجموعه‌ها كاربردي ندارد.406

اسلاید 407: 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.مثال :407

اسلاید 408: در رياضيات مي‌توانيم مجموعه‌ها را با هم اجتماع، اشتراك و تفاضل كنيم كه اين عمليات در پاسكال با عملگرهاي +، * و - به ترتيب مي‌باشد. اجتماع دو مجموعه تركيبي از همه عضوهاي آنها است و اشتراك يعني عضوهايي كه در هر دو مجموعه مشترك است و تفاضل يعني اعضايي كه در مجموعه اول مي‌باشد و در مجموعه دوم وجود ندارد. عملگرها روي مجموعه‌ها 408

اسلاید 409: مثال :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.409

اسلاید 410: در استفاده از مجموعه ها به نکات زیر توجه کنید :1. آرگومان ورودي روالها مي‌تواند مجموعه باشد كه قبلاً در تايپ تعريف شده باشد، نه اينكه مستقيم در روال به عنوان آرگومان بيايد. ولي خروجي يك تابع نمي‌تواند از نوع مجموعه باشد.2. براي نوشتن يا خواندن مجموعه‌ها بايد عضو به عضو عمليات صورتبگيرد و مستقيماً توابع Write، Read روي آنها كار نمي‌كنند. 410

اسلاید 411: مثال : برنامه‌اي بنويسيد كه تعداد محدودي عدد مختوم به 1- را از ورودي بخواند و در يك مجموعه از اعداد صحيح قرار بدهد. سپس اعضاي اين مجموعه را با توجه به مجموعه ساخته شده در خروجي چاپ كند:Program test ;Var num , temp : set of byte; I , c : integer ;Begin Writln (Enter numbers: ); Readln( I ) ; Num := [ ] ; c := 0 ;411

اسلاید 412: 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 }412

اسلاید 413: داده‌هاي شمارشي (Enumeration) داده‌هاي شمارشي، يك مجموعه مرتب از اعداد است كه در برنامه، هر عدد داراي نام بخصوصي است. اين نامها در داخل دو پرانتز باز و بسته قرار مي‌گيرند و بترتيب از صفر مقدار مي‌گيرند مگر اينكه برنامه‌نويس به آنها مقدار مخصوصي بدهد. 413

اسلاید 414: به مثال زير توجه كنيد : Type Cars_type = (Peykan, Pride, Pegout, PK);Var Cars: cars_type;حال در برنامه cars مي‌تواند مقادير داخل داده‌هاي شمارشي را بگيرد:cars:= Pride;cars:= PK;414

اسلاید 415: 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 415

اسلاید 416: متغير داده شمارشي شبيه مجموعه‌ها حداكثر داراي 256 عضو مي‌تواند باشد كه از صفر تا 255 شماره‌گذاري مي‌شود و لذا يك بايت حافظه را اشغال مي‌كند.نکته : 416

اسلاید 417: عمليات روي داده‌هاي شمارشيداده‌هاي شمارشي همانند هر نوع تايپي مي‌توانند در type برنامه تعريف شود و به عنوان آرگومانهاي روالها و يا خروجي توابع مي‌تواند درنظر گرفته شود ولي حتماً بايد در type تعريف شده باشد و مستقيماً نمي‌توان بكار برد. اين عمل مشابه مجموعه‌ها و آرايه‌ها نيز مي‌باشند، لذا ابتدا در type تعريف مي‌شود، سپس به عنوان ورودي و يا خروجي روالها استفاده مي‌شود وگرنه خطاي كامپايلري پيش خواهد آمد. همچنين مي‌توان در آرايه‌ها از داده‌ها شمارشي استفاده كرد.417

اسلاید 418: مثال : مشابه مجموعه‌ها نمي‌توان داده‌هاي شمارشي را مستقيماً 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 Of418

اسلاید 419: 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.419

اسلاید 420: تمرينات اگر A=[1,3,5,7] و B=[2,4,6] و C=[1,2,3] باشد عبارات زير راارزيابی کنيد.الف- A + (B –C) ب- A + (B*C)ج- A + B + Cد – 2 in A420

اسلاید 421: برنامه‌اي بنويسيد تا مجموعه اي از كاراكترهاي كوچك را گرفته و به يك مجموعه از كاراكترهاي حروف بزرگ متناظر با آن تبديل كند. به كمك داده‌هاي شمارشي، برنامه اي بنويسيد كه نام دانشجويان يك كلاس را در برگيرد و هر دانشجو نيز يك شماره داشته باشد. سپس با دريافت نام او شماره او در نمايشگر چاپ شود.421

اسلاید 422: فصل 13(Records) ركوردها هدفهاي كلي مفهوم ركورد و اجزاي آن انواع ركوردها و استفاده از آن در برنامه معرفي مزاياي ركوردها در برنامه422

اسلاید 423: ÷ هدفهاي رفتاري مواقع لزوم ركورد را تشخيص دهد. از ركوردها در برنامه‌اش استفاده كند. برنامه‌هاي بزرگ و با داده‌هاي زياد بنويسد.دانشجو پس از مطالعه اين فصل بايد بتواند:423گروه آموزشی مهندسی ایران Iranian Engineering Group WWW.MOHANDE30.COM

اسلاید 424: مقدمه نوع داده ساخت‌يافته‌اي كه در اينجا مطرح مي‌شود، ركورد نام دارد كه جهت نگهداري داده‌هاي مختلف نظير نام، نام خانوادگي، سن و آدرس براي يك دانشجو بكار مي‌رود. ركوردها برخلاف آرايه‌ها كه داراي عناصر از يك جنس و نوع هستند، داراي عناصر از انواع مختلف مي‌باشند. اطلاعات ازنوع مختلف را نمي‌توان در آرايه نگهداري كرد چرا كه داراي جنس مشابه نيستند و لذا از ساختاري به نام ركورد استفاده مي‌شود.424گروه آموزشی مهندسی ایران Iranian Engineering Group WWW.MOHANDE30.COM

اسلاید 425: تعريف ركوردها نوع داده ساخت‌يافته ای که از یک سری داده ها یا اطلاعات مرتبط به هم تشکیل می شود.هر کدام از اطلاعات را یک فیلد می نامند .‌بطور كلي تعريف نوع ركورد در زير آمده است:TypeName = RecordField1-list : type1;Field2-list : type2;....Fieldn-list : typen; End;425

اسلاید 426: براي ساختن ركورد، از كلمه كليدي Record استفاده مي‌شود كه مطابق زيرمي‌باشد:Type Student = Record Name: String [10]; Family: String [15]; Age: integer; Address: String; End;در اين تعريف Student از نوع Record است. حال مي‌توان در var برنامه تعريف كرد:VarS: Student;426

اسلاید 427: دسترسي به فيلدهاي ركوردبراي دسترسي به فيلدهاي ركورد ازعلامت . استفاده مي‌شود. يعني بصورت‌زير: نام فيلد . نام متغير ركورد مثال: برنامه‌اي بنويسيد كه ركوردي از نوع ‌اعداد ايجاد كرده و مقادير آنرا مقدارهي‌‌ كند.427

اسلاید 428: 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.428

اسلاید 429: مثال : برنامه‌اي بنويسيد كه ركورد يك دانشجو را داشته باشد و با توجه به جنس او كلمه آقا و يا خانم را به همراه نام و نام خانوادگي‌اش را چاپ كند.Type Student = recordId: integer;Name: string[10];Family: string[15];Sex: char;Age: integer; End;Var Stu: student;429

اسلاید 430: 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.430

اسلاید 431: بدست آوردن حجم يك ركوردبراي بدست آوردن فضاي اشغال شده توسط ركورد ابتدا بايد فضاي اشغال شده توسط تمامي‌فيلدها را بدست آورده و سپس باهم جمع كنيم. مثال زير را درنظر بگيريد:431

اسلاید 432: 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 بايت فضا اشغال مي‌شود.432

اسلاید 433: ركوردهاي تودرتو فيلدهاي يك ركورد مي‌توانند از هر نوعي باشد، از جمله مي‌توانند از نوع ركورد ديگري باشند. در اينجا نيز مشابه قبل دسترسي به همان صورت مي‌باشد فقط به تعداد ركوردهاي تودرتو، . پيش مي‌آيد. به مثال زيرتوجه‌ كنيد:TypeRec = record a, b: integer; c: char; x: Record p: integer; q: integer; End; End;433

اسلاید 434: Var r: Rec;دراينجا يك ركورد تودرتو به نام Rec تعريف شده ‌است كه متغير r از آن نوع ‌تعريف شده است. سپس براي دسترسي به فيلدهاي a , b ,c مي‌توان به صورت زير عمل كرد:r.ar.bولي براي دسترسي به فيلدهاي p ,q چون متعلق به ركورد x نيز هستند داريم:r.x.pr.x.q434

اسلاید 435: آرايه‌اي از ركوردها هنگامي‌كه ما تعدادي داده مشابه داريم ولي در هريك، داده‌هاي مختلفي وجود دارد مي‌توانيم يك ركورد تعريف كرده، سپس آرايه‌اي از آن تعريف كنيم. Type Student = recordName: string[10];Id: integer;Age: integer; End; Arr_stu: array[1..10] of student;Var S: Arr_stu;435

اسلاید 436: در بالا ابتدا يك ركورد دانشجو تعريف شده است، سپس به تعداد 10 نفر دانشجو تحت آرايه Arr_stu شكل گرفته است و سرانجام متغيري به نام S از نوع آن تعريف شده است. مشابه ساختار آرايه، چيزي عوض نشده است و فقط هر عنصر آرايه، يک ركورد مي‌باشد كه داراي سه فيلد مطابق جدول فوق مي‌باشد. براي دسترسي به آرایه فوق داريم:S[1].name S[1].idS[1].ageS[2].nameS[2].id...... 436

اسلاید 437: ارسال ركورد به زيربرنامه‌ها ركوردها را مي‌توان مشابه انواع تعاريف ساده ديگر به صورت پارامترهاي متغير و مقدار به زيربرنامه ارسال كرد. ولي نوع برگشتي توابع نمي‌تواند از نوع ركورد باشد، يعني حتماً بايد از نوع ساده نظير integer، char و... باشد و از انواع تركيبي نظير ركورد، آرايه، مجموعه و فايل نمي‌تواند باشد.اگر بخواهيم ركوردي را بصورت پارامتر به زيربرنامه ارسال كنيم، ابتدا بايد آنرا در type تعريف كرده و سپس ارسال شود وگرنه كامپايلر خطا صادر مي‌كند. 437

اسلاید 438: مثال : مي‌خواهيم برنامه‌اي بنويسيم كه ركورد 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;438

اسلاید 439: 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;439

اسلاید 440: 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. 440

اسلاید 441: تمرينات براي گونه‌هاي حيوانات يك پارك نظير پرندگان وحشي ركوردي شامل نام، دسته، محيط زندگي، سن بسازيد. در نظر بگيريد كه در پارك 100 گونه از يك پرنده وحشي وجود دارد (راهنمايي: آرايه‌اي از ركورد با فيلدهاي گفته شده بسازيد). برنامه‌اي بنويسيد كه براي نگهداري تاريخ به صورت روز، ماه و سال براي 100 سال بكار رود. در واقع به صورت تقويم باشد و جمله‌اي در مورد آن تاريخ را نگهداري كنيد؟ (راهنمايي: آرايه‌اي 366 تايي از روز بهمراه آرايه‌اي از 12 ماه و يك سال و يك رشته را به صورت يك ركورد در نظر گرفته سپس براي 100 سال بصورت يك آرايه صدتايي در نظر بگيريد.)441

اسلاید 442: فصل 14(Files) فــايـلهاهدفهاي كلي مفهوم فايل و انواع آن موارد استفاده از فايلها442گروه آموزشی مهندسی ایران Iranian Engineering Group WWW.MOHANDE30.COM

اسلاید 443: ÷ هدفهاي رفتاري در برنامه‌اش از فايلها استفاده كند.. براي برنامه‌هاي با داده‌هاي زياد از فايل استفاده كند.. با فايلهای داده‌اي و بايزي برنامه‌نويسي كند.دانشجو پس از مطالعه اين فصل بايد بتواند:443گروه آموزشی مهندسی ایران Iranian Engineering Group WWW.MOHANDE30.COM

اسلاید 444: مقدمهبراي ذخيره دائمي داده‌ها از ساختاري به نام فايل (File) استفاده مي‌كنيم. تاكنون همه عمليات لازم در حافظه اصلي انجام مي‌گرفت كه گذرا و فقط به زمان اجراي برنامه و روشن بودن كامپيوتر بستگي داشت. ولي در فايلها چنين نيست، بلكه داده‌ها در فايلهايي قرار دارند كه حتي بعد از خاموش كردن كامپيوتر، بعدها قابل دسترسي است.444گروه آموزشی مهندسی ایران Iranian Engineering Group WWW.MOHANDE30.COM

اسلاید 445: فايلهاي متني (Text) يك فايل متني از تعداد كاراكتر تشكيل شده است كه با يك اسم در روي ديسك ذخيره شده است. چون فايل از نوع متني است مي‌توانيد داده‌هاي داخل آنرا مشاهده كنيد.ساختار داده‌ها در يك فايل متني بدين صورت است كه تعدادي خط وجود دارد كه به علامت EOLN ختم مي‌شوند و در انتهاي فايل نيز علامت EOF قرار دارد. طول خطوط نامشخص است و اندازه فايل ممكن است بسيار بزرگ يا كوچك و يا تهي باشد. 445گروه آموزشی مهندسی ایران Iranian Engineering Group WWW.MOHANDE30.COM

اسلاید 446: طريقه ایجاد يك فايل متنيتعریف یک متغیر فایلی نسبت دادن اسم فایل به متغیر فایلی ایجاد فایل با دستور Rewrite446

اسلاید 447: تعریف یک متغیر فایلیName : Text;نسبت دادن اسم فایل به متغیر فایلیAssign(FileVar , ‘NameFile’ )ایجاد فایل با دستور RewriteRewrite( FileVar )447

اسلاید 448: مثال : برنامه‌اي بنويسيد كه از ورودي 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);448

اسلاید 449: For i: = 1 to 10 do Writeln (f, A[i]); Writeln (f, Sum); Close (f);End.بعد از نوشته شدن اطلاعات در فایل ، فایل باید بسته شود برای اینکار از روال زیر استفاده می شود :Close(FileName)449

اسلاید 450: طريقه خواندن اطلاعات از يك فايل متنيتعریف یک متغیر فایلی نسبت دادن اسم فایل به متغیر فایلی باز کردن فایل برای خواندن با دستورReset450

اسلاید 451: باز کردن فایل برای خواندن با دستورReset ( FileName )دستور Read وReadln برای خواندن اطلاعات از فایل بکار می روند .Readln بعد از خواندن داده‌هاي مورد نظر به سطر بعد مي‌رود. اين عمل براي Writeln نيز چنين مي‌باشد. ولي قبل از استفاده از اين دستورات بايد فايل متني براي خواندن يا نوشتن باز شود. دستور Reset فايل متني را براي خواندن باز مي‌كند و مكان نما را ابتداي فايل مي‌برد. دستور Rewrite فايل متني را براي نوشتن در آن باز كرده، و مكان نما را به ابتداي آن مي‌برد.451

اسلاید 452: حال بافرض موجود بودن فایل متني 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.452

اسلاید 453: مثال : برنامه‌اي بنويسيد كه يك فايل متني شامل چند جمله را از ورودي دريافت كرده و يك كپي از فايل درخروجي بسازد.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);453

اسلاید 454: در اين برنامه ابتدا دو فايل به نامهايشان نسبت داده مي‌شوند و ترتيب براي خواندن و نوشتن باز مي‌شوند. سپس توسط eof شرط خاتمه فايل ورودي يعني f1 بررسي مي‌شوند و در يك حلقه تو در تو while شرط خاتمه خطوط نيز توسطeoln بررسي شده و كاراكتر‌ها از فايل ورودي خوانده شده و در فايل خروجي نوشته مي‌شوند. 454

اسلاید 455: 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.455

اسلاید 456: فايلهاي دودويي و نوع‌دار(Binary & Typed ) اين نوع فايل‌ها در زبان پاسكال از تايپهاي مختلف record ,array ,read ,integer ,char و … تشكيل شده است كه نياز به پردازش متنوعشبيه مرتب‌سازي، جستجو، حذف و… دارند. اين فايلها پس از ايجاد توسط برنامه، قابل رؤيت توسط ويراشگرها نيستند، بلكه به صورت كد‌هاي اسكي مي‌باشند يعني دودويي مي‌باشند. نحوه دسترسي به اطلاعات آنها نيز به صورت تصادفي (Random) است.456

اسلاید 457: طريقه ایجاد يك فايل نوع دارتعریف یک متغیر فایلی نسبت دادن اسم فایل به متغیر فایلی ایجاد فایل با دستور Rewrite457

اسلاید 458: تعریف یک متغیر فایلیName : File Of FileType ;نسبت دادن اسم فایل به متغیر فایلیAssign(FileVar , ‘NameFile’ )ایجاد فایل با دستور RewriteRewrite( FileVar )458

اسلاید 459: نحوه تعريف يك فايل دودويي نوع‌دار از انواع مختلف در زير آورده ‌شده ‌است:Const n=100;Type Student = Record Name: string[10]; Family: String[15]; Age: integer; ID: integer; end;Sarray = Array [1..n] of student;459

اسلاید 460: Varفايل دودويي از نوع كاراكتر Bf1: file of char;فايل دودويي از نوع صحيح Bf2: file of integer;فايل دودويي از نوع ركورد دانشجو Bf3: file of student;فايل دودويي از مجموعهA تا Z Bf6: file of set of A..Z; مثال : 460

اسلاید 461: مثال : برنامه‌اي بنويسيد كه تعداد رشته (حداكثر 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.461

اسلاید 462: در جدول صفحه بعد تمام روالهاي كتابخانه‌اي پاسكال جهت كار با فايلها آورده شده است كه به همراه توضيحات لازمه جهت كار با آنها مي‌‌باشد. همچنين براي هر تابع و رويه محل مورد استفاده آن در ستونی مشخص شده است . 462

اسلاید 463: 463

اسلاید 464: 464

اسلاید 465: مثال های حل شده مثال : برنامه‌اي بنويسيد كه تعداد خطوط يك فايل متني را بدست آورد.Var F: text ; ch : char ; str: string[20]; count: integer;Begin Write (Enter the file name: ); Readln(str); Assign(f,str); Reset(f);465

اسلاید 466: 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.466

اسلاید 467: مثال : ركوردي از كتاب‌ها در نظر گرفته، تعداد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;467

اسلاید 468: 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. 468

اسلاید 469: تمرينات برنامه‌اي بنويسيد كه از يك فايل متني از اعداد حقيقي كه در سطرها و ستونها مختلف قرار دارند، ميانگين داده‌ها را بدست آورده و در مانيتور چاپ كند.برنامه‌اي بنويسيد كه در انتهاي يك فايل متني، همان فايل متني را اضافه كند. برنامه‌اي بنويسيد كه در يك فايل نوع دار از كاراكترها، اطلاعات آماري هر كاراكتر را بدست آورده، يعني تعداد هر كاراكتر را بدست آورد. مثلاً كاراكتر A به تعداد 45 تا و كاراكتر B به تعداد 36 تا و…469گروه آموزشی مهندسی ایران Iranian Engineering Group WWW.MOHANDE30.COM

اسلاید 470: فصل 15تحليل الگوريتمها هدفهاي كلي مفهوم و تعريف الگوريتم مفهوم كارايي يك الگوريتم مرتبه يك الگوريتم470گروه آموزشی مهندسی ایران Iranian Engineering Group WWW.MOHANDE30.COM

اسلاید 471: ÷ هدفهاي رفتاري برنامه خود را تحليل زماني نمايد. مرتبه الگوريتم را بدست آورد. الگوريتمهاي بازگشتي را تحليل نمايد.دانشجو پس از مطالعه اين فصل بايد بتواند:471گروه آموزشی مهندسی ایران Iranian Engineering Group WWW.MOHANDE30.COM

اسلاید 472: مقدمه تحليل يك الگوريتم يعني ارزيابي روشهاي مختلف حل آن مسئله، بررسي و محاسبه بهترين و بدترين حالتها، بصورتي كه با توجه به شرايط بهترين حالت را بتوان انتخاب كرد. الگوريتم در واقع تعداد محدودي از دستورالعملها می باشد كه بترتيب اجرا مي‌شوند و هدف خاصي را دنبال مي‌كنند472گروه آموزشی مهندسی ایران Iranian Engineering Group WWW.MOHANDE30.COM

اسلاید 473: تعريف مرتبه يا پيچيدگي الگوريتم (O بزرگ) براي بدست آوردن بدترين حالت اجراي يك الگوريتم يا مرتبه پيچيدگي الگوريتم از O بزرگ استفاده مي‌كنيم و بنا به تعريف عبارتست از f(n)=O(g(n)) و مي‌خوانيم f(x) از مرتبه g(x) مي‌باشد، اگر و تنها 473گروه آموزشی مهندسی ایران Iranian Engineering Group WWW.MOHANDE30.COM

اسلاید 474: رمثال : 1+n2=f(n) مي‌توان با در نظرگرفتن g(n)=n و3=c رابطه زیر حاصل می شود :1n n>=3 <= cg(n)=1n+2f(n)=لذا مي‌توان گفت، پيچيدگي زماني f(n) از مرتبه O(n) مي‌باشد.474گروه آموزشی مهندسی ایران Iranian Engineering Group WWW.MOHANDE30.COM

اسلاید 475: بدست آوردن مرتبه الگوريتمها براي بدست آوردن مرتبه اجراي الگوريتمها بايد به دقت بررسي شود و تعداد تكرار آن الگوريتم بدست آورده شود. يعني در واقع تعداد تكرارها بدست آورده شود و سپس با هم جمع شده و مطابق مثالهاي قبلي به پيچيدگي زمان واقعي رسيد. براي اين منظور از الگوريتمهاي ساده شروع كرده و به پيچيده مي‌رسيم.475گروه آموزشی مهندسی ایران Iranian Engineering Group WWW.MOHANDE30.COM

اسلاید 476: فرض كنيد الگوريتمي داراي حلقه‌هاي ساده به شكل زير باشد:x:= 0;For I :=1 to n do x:=x+1; كه در آن n تعداد ورودي مي‌باشد. يعني حلقه for بستگي به پارامتر n دارد. همان طور كه از تعريف حلقه for برمي‌آيد تعداد 1+1-n تكرار يعني n تكرار وجود دارد و لذا قطعه برنامه فوق از مرتبهO(n) مي‌باشد.476گروه آموزشی مهندسی ایران Iranian Engineering Group WWW.MOHANDE30.COM

اسلاید 477: مثال : مرتبه تابع زير را بدست آوريد:Function fact ( n : integer ) : integer ;var f,i: integer;begin f:=1; for I := 1 to n do f:=f*i; fact:=f;end;477گروه آموزشی مهندسی ایران Iranian Engineering Group WWW.MOHANDE30.COM

اسلاید 478: تابع فوق فاكتوريل عدد n را بر مي‌گرداند. همانطور كه مي‌بينيد تابع شامل يك حلقه for ساده بوده كه از يك تا n متغير بوده و لذا n بار تكرار مي‌شود. 2 جمله ساده نيز وجود دارد که زمان های ثابتی دارند. بنابراین مرتبه تابع بالا برابر است با : O(n)478گروه آموزشی مهندسی ایران Iranian Engineering Group WWW.MOHANDE30.COM

اسلاید 479: تمرينات پيچيدگي زماني توابع زير را بدست آوريد:479

اسلاید 480: پيچيدگي زماني تابع زير را بدست آوريد: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.480

18,000 تومان

خرید پاورپوینت توسط کلیه کارت‌های شتاب امکان‌پذیر است و بلافاصله پس از خرید، لینک دانلود پاورپوینت در اختیار شما قرار خواهد گرفت.

در صورت عدم رضایت سفارش برگشت و وجه به حساب شما برگشت داده خواهد شد.

در صورت نیاز با شماره 09353405883 در واتساپ، ایتا و روبیکا تماس بگیرید.

افزودن به سبد خرید