Presentation is loading. Please wait.

Presentation is loading. Please wait.

ساختمان داده ها به زبان C

Similar presentations


Presentation on theme: "ساختمان داده ها به زبان C"— Presentation transcript:

1 ساختمان داده ها به زبان C
دانشگاه پيام نور ساختمان داده ها به زبان C تهيه کننده: سيده فاطمه نوراني گروه: کامپيوتر Data Structure in C

2 ساختمان داده ها به زبان C
شناسنامه منبع عنوان منبع: ساختمان داده ها به زبان C مترجم: امير عليخانزاده انتشارات: باغاني منبع اصلي: Fundamental of data Structure in C Horowitz Ellis

3 جايگاه درس در رشته کامپيوتر
ضرورت اين درس: ضرورت نياز به زبانهاي سطح بالا ضرورت ترجمه برنامه هاي نوشته شده با زبان سطح بالا به برنامه به زبان ماشين تنوع زبانهاي برنامه نويسي سطح بالا دروس پيش نياز: نوع درس: اجباري تعدادکل ساعات تدريس: 30 تعداد جلسات تدريس:10

4 فصل اول : مفاهيم اساسي اهداف آشنايي با سيکل زندگي نرم افزار
آشنايي با الگوريتم

5 1-1 سيکل زندگي نرم افزار-نیازمندی ها
نیازمندیها تمام پروژه هاي بزرگ برنامه نويسي با مجموعه اي از مشخصات و خصوصياتي که اهداف پروژه را مشخص مي کند، شروع مي شود. اين نيازمنديها اطلاعاتي را به برنامه نويسان مي دهند(ورودي) و نيز نتايجي را که بايد ايجاد گردد(خروجي) تعيين مي کنند.

6 1-1 سيکل زندگي نرم افزار- تحلیل
تحليل: در اين مرحله مساله را به بخشهاي قابل کنترل تقسيم مي کنند. در تحليل يک سيستم دو شيوه وجود دارد : 1- شيوه از بالا به پايين 2- شيوه از پايين به بالا

7 1-1 سيکل زندگي نرم افزار- طراحی
طراحي اين مرحله ادامه کاري است که در مرحله تحليل انجام مي شود. طراح سيستم را از دو نقطه نظر بررسي مي کند: از نظرداده هاي مقصود(data objects) مورد نياز برنامه از نظر اعمالي که بر روي آنها انجام مي شود. اين ديدگاه به مشخصات الگوريتم ها و فرضيات خط مشي ها ي طراحي الگوريتم نياز دارد. ايجاد نوع داده مجرد

8 1-1 سيکل زندگي نرم افزار- ... پالايش(اصلاح) و کدنويسي: در اين مرحله، نمايشي براي داده هاي مقصد خود انتخاب مي شود و براي هر عملي که بر روي آنها انجام مي شود، الگوريتم نوشته مي شود. بازبيني: در اين مرحله درستي برنامه ها اثبات مي شود و برنامه ها با انواع داده هاي ورودي مختلف تست و خطاهاي برنامه رفع مي شود. جنبه هاي مهم بازبيني: اشکال زدايي تست اثبات درستی

9 1-1 نمودار سيکل زندگي نرم افزار
نيازمنديها تحليل طراحي پالايش و کدنويسي بازبيني

10 2-1 تعريف الگوريتم الگوريتم مجموعه اي از دستورالعمل ها است که
2-1 تعريف الگوريتم الگوريتم مجموعه اي از دستورالعمل ها است که اگر دنبال شوند، موجب انجام کار خاصي مي گردد

11 2-1 شرايط الگوريتم ورودي: يک الگوريتم مي تواند هيچ يا چندين کميت ورودي داشته باشدکه از محيط خارج تامين مي شود. خروجي: الگوريتم بايستي حداقل يک کميت به عنوان خروجي داشته باشد. قطعيت: هر دستورالعمل بايد واضح و بدون ابهام باشد. محدوديت: اگر دستوذالعمل هاي يک الگوريتم را دنبال کنيم ،براي تمام حالات ، الگوريتم بايد پس از طي مراحل محدودي خاتمه يابد. کارايي: هر دستورالعمل بايد به گونه اي باشد که با استفاده از قلم و کاغذ بتوان آن را با دست نيز اجرا نمود.

12 2-1 مثالی از الگوريتم: الگوریتم مرتب سازي
2-1 مثالی از الگوريتم: الگوریتم مرتب سازي for (i=0 ; i<n ;i++){ Examine list [ i ] to list [n-1] and suppose that the smallest integer is at list [min]; Interchange list [ i ] and list [min];

13 2-1 الگوريتم بازگشتي تابع چيزي است که توسط تابع ديگر فراخوانده مي شود . توابع مي توانند خودشان را صدا بزنند (بازگشت مستقيم ) يا مي توانند توابعي که تابع فراخواننده را صدا ميزنند(بازگشتي غيرمستقيم) را احضار نمايند.

14 2-1 مثال الگوريتم جستجوي دودويي
int binsearch ( int list [ ] ، int searchnum ، int left ، int right ) { /* search list [0] <= list [1] <= … <=list [ n-1 ] for searchnum Return its position if found . Otherwise return -1 */ int middle ; if (left <= right ) { middle = ( left + right ) / 2 ; switch ( COMPARE ( list [ middle ] ، searchnum )) { case -1 : return binsearch ( list ، searchnum ، middle +1 ، right ) ; case 0 : return middle ; case 1 : return binsearch ( list ، searchnum ، left ، middle -1 ) ; } return -1 ;

15 3-1 آرايه ، ساختار و نوع داده
مجموعه اي از عناصر از يک نوع داده مي باشد مجموعه اي از عناصر است که لزومي ندارد داده هاي آن يکسان باشد مجموعه اي از انواع داده مقصد(object) و عملکردهايي است که بر روي اين نوع داده ها عمل مي کنند آرايه ساختار نوع داده

16 3-1 نوع داده اي مجرد نوع داده مجرد یا انتزاعی (ADT) که شامل مشخصات داده ها و اعمالی که بر روی آنها انجام می شود. جهت جداسازی پياده سازی و نمایش داده ها از یکدیگر.

17 توابع يک نوع داده به گروه هاي زير تقسيم مي شوند:
3-1 نوع داده مجرد توابع يک نوع داده به گروه هاي زير تقسيم مي شوند: 1- ايجادکننده/ سازنده 2- تبديل کنندگان 3- مشاهده کنندگان / گزارش کنندگان

18 4-1 تحليل نحوه اجراي يک برنامه
معيارهاي محک زدن يک برنامه آيا برنامه اهداف اصلي کاري را که مي خواهيم، انجام مي دهد؟ آيا برنامه درست کار مي کند؟ آيا برنامه مستند سازي شده است تا نحوه استفاده و طرز کار با آن مشخص شود؟ آيا برنامه براي ايجاد واحدهاي منطقي ، به طور موثر از توابع استفاده مي کند؟ آيا کد گذاري خوانا است؟ آيا برنامه از حافظه اصلي و کمکي به طور موثري استفاده مي کند؟ آيا زمان اجراي برنامه براي هدف شما قابل قبول است؟ اين قسمت مربوط به تخمين هاي حافظه و زمان مورد نياز بوده و مستقل از ماشين است . اين قسمت را تحليل نحوه اجراي برنامه مي ناميم.

19 4-1 ميزان حافظه يا پيچيدگي فضاي يک برنامه
ميزان حافظه يا پيچيدگي فضاي يک برنامه مقدارحافظه مورد نيازبراي اجراي کامل يک برنامه است. ميزان يا پيچيدگي زمان يک برنامه مقدار زمان کامپيوتر است که براي اجراي کامل برنامه لازم است.

20 نيازمنديهاي فضاي متغير
4-1 ميزان حافظه فضاي مورد نياز يک برنامه شامل موارد زير است : اين مطلب به فضاي مورد نيازي که به تعداد و اندازه ورودي و خروجي بستگي ندارد، اشاره دارد. اين مورد شامل فضاي مورد نياز متغيرهاي ساخت يافته اي است که اندازه آن بستگي به نمونه I از مساله اي که حل مي شود، دارد. نيازمنديهاي فضاي ثابت نيازمنديهاي فضاي متغير

21 4-1 ميزان حافظه(ادامه) نيازمنديهاي فضاي کل نيازمنديهاي فضاي ثابت
نيازمنديهاي فضاي متغير

22 4-1 زمان T(P) برنامه زمان T(P) برنامه عبارتست ازمجموع زمان کامپايل و
زمان اجراي برنامه. زمان کامپايل مشابه اجزاي فضاي ثابت است زيرابه خصيصه هاي نمونه بستگي ندارد. را به صورت زير تعريف مي شود:

23 4-1 مرحله برنامه يک مرحله برنامه ، قسمت با معني برنامه است
( از لحاظ معنايي يا نحوي) که زمان اجراي آن مستقل از خصيصه هاي نمونه باشد

24 4-1علامت گذاري مجانبي(O، Ω ،Θ)(Asymptotic)
انگيزه براي تعيين تعداد مراحل، قابليت مقايسه پيچيدگي دو برنامه که يک تابع را اجرا مي کنند و پيش بيني رشد و افزايش زمان اجرا با تغيير صفات نمونه مي باشد. f(n)=O(g(n)) [Big “oh” ] است ( خوانده مي شود (“f of n is big oh of g of n “ اگر و فقط اگر به ازاي مقادير ثابتي از f(n)،n0،c براي تمامي مقاديز n کمتر يا مساوي g(n) باشد (n ≥ n0)

25 4-1علامت گذاري مجانبي(O، Ω ،Θ)(Asymptotic)
O(n) : يک تابع خطي ناميده مي شود : تابع درجه دو ناميده مي شود قضيه : اگر باشد، بنابراين خواهد بود

26 4-1 علامت گذاري مجانبي(O، Ω ،Θ)(Asymptotic)
تعريف:]امگا [: f(n)=Ω(g(n)) مي باشد(خوانده مي شود f(n) امگاي g(n) اگر و فقط اگر به ازاي مقادير ثابت مثبت c و n0 ، f(n)≥cg(n) باشد(براي تمام مقادير n به شرطي که n≥n0 باشد) قضيه : اگر باشد، و بنابراين خواهد بود

27 4-1 علامت گذاري مجانبي(O، Ω ،Θ)(Asymptotic)
تعريف تتا[Theta] : f(n) = θ(g(n)مي باشد (خوانده مي شود f(n) تتاي (g(n) اگر و فقط اگر به ازاي مقادير ثابت c1 و c2 و n0، c1g(n)<= f(n) <= c2g(n) وجود داشته باشد (براي تمام مقاديرn>=n0) نشانه گذاري تتا از دو نشانه گذاري ذکر شده “ big oh “ و امگا دقيق تر مي باشد . f(n) = Θ(g(n)) مي باشد اگر و فقط اگر g(n) هم به عنوان کرانه بالا و هم به عنوان کرانه پايين در f(n) باشد.

28 4-1 علامت گذاري مجانبي(O، Ω ،Θ)(Asymptotic)
قضيه : اگر باشد، و بنابراين خواهد بود

29 4-1 مثال(پيچيدگي جمع ماتريس ها)
Asymptotic complexity Statement Θ(rows) Θ(rows.cols) Void add (int a []MAX-SIZE…) { int I،j; For(i=0;i<rows ; i++) For[j=0 ; j<cols ; j++) C[i][j]=a[i][j]+b[i][j]; } Total

30 5-1روش هاي اندازه گيري زمان رويدادها در C
دو روش متفاوت وجود دارد : روش و مدل اول از ساعت (clock) براي زمان بندي رويدادها استفاده مي کند. اين تابع ، زمان تلف شده از آغاز برنامه به وسيله پردازنده را مي دهد. براي زمان بندي يک رويداد دوبار از ساعت استفاده مي شود. يک مرتبه در ابتداي رويداد و يک مرتبه در انتهاي آن. روش يا مدل دوم ازtime استفاده مي کند. اين تابع ، زمان را بر حسب ثانيه به عنوان نوع پيش ساخته time-t برمي گرداند. بر خلاف clock ، time فقط يک پارامتر دارد که به وسيله آن موقعيتي را که زمان بايد نگهداري شود ، مشخص مي کند.

31 5-1 توليد داده هاي آزمايشي براي ايجاد بدترين حالت اجرا
ايجاد داده هاي آزمايشي که منجر به بدترين حالت اجرا مي شود ، هميشه ساده نيست. در بعضي از موارد لازم است که از يک برنامه کامپيوتري براي ايجاد بدتريت حالت استفاده مي شود. براي هر مجموعه مقادير از صفات نمونه مورد نظر ، يک داده آزمايشي تصادفي با عددي به اندازه کافي بزرگ ايجاد مي کنيم زمان اجراي هر کدام از اين داده هاي آزمايشي به دست مي آيد

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

33 فصل دوم : آرايه ها و ساختارها
آرايه مجموعه اي از زوج ها ، شامل انديس و مقدار است (<index ، value>) . به ازاي هر انديس يک مقدار مربوط به آن انديس وجود دارد که به زبان رياضي آنرا تناظر يا انگاشت ناميده مي شود. بازيابي در رابطه با آرايه به دو عمل اساسي نياز است : ذخيره سازي مقادير

34 1-2 آرايه ها تابعCreat(J،list) : يک آرايه جديد تهي با طول مناسب را توليد مي کند. تمتم مقادير در ابتدا تعريف نشده اند. تابع Retrieve : يک آرايه و يک انديس را به عنوان ورودي دريافت مي کند و يک مقدار مربوط به انديس را اگر انديس معتبر باشد برميگرداند و گرنه يک خطا را بازمي گرداند. تابع store : براي وارد کردن زوج جديدي شامل < انديس، مقدار> به کار مي رود و آرايه اوليه افزايش يافته با زوج جديد،<مقدار،انديس> را بازمي گرداند.

35 1-2 آرايه ها نکته آرايه در زبان C به صورت مثال در زير آمده است :
int list [5] نکته در زبان C تمام آرايه ها از انديس 0 شروع مي شوند.

36 ساختارها ساختار آرايه ها مجموع داده هاي از يک نوع مي باشند. در C روش ديگري براي دسته بندي گروهي از داده وجود دارد . اين روش اجازه مي دهد تا داده ها از انواع متفاوتي باشند. اين امکان را struct مي گويند که مختصر structure است. يک ساختار مجموعه اي از اقلام داده ها مي باشد که هر قلم داده به وسيله نوع و نام آن مشخص گرديده است.

37 ساختارها مثال: Struct{ char name[10]; int age; float salary; }person
نام شخص به صورت يک آرايه کاراکتري است . يک مقدار صحيح که نشان دهنده سن همان شخص است. يک مقدار float که حقوق شخص را معين مي کند.

38 يونيون ها يونيون اعلان يونيون مشابه تعريف و اعلان يک ساختار است با اين تفاوت که فيلدهاي يک يونيون بايد در حافظه با هم مشترک باشند يعني فقط يک فيلد يونيون در هر زمان فعال مي گردد.

39 ساختارهاي خود ارجاعي يک ساختار خودارجاعي ساختاري است که در آن يک جز
يا بيشتر ، اشاره گري به خود آن مي باشد. ساختارهاي خود ارجاعي معمولا به روالهاي مديريت حافظه پويا احتياج دارند (malloc free) تا به راحتي حافظه را گرفته و آزاد کنند.

40 ليست ليست ساده ترين و متداول ترين نوع ساختمان داده ها ، ليست هاي مرتب شده يا خطي هستند. ليست ها شامل اقلام داده به صورت مي باشند. مثال : روزهاي هفته ( شنبه ... جمعه )

41 اعمال صورت گرفته بر روي ليست ها
پيدا کردن طول يک ليست خواندن اقلام داده يک ليست از چپ به راست يا بر عکس بازيابي i امين عنصر از يک ليست (0≤ i < n) تعويض يک قلم اطلاعاتي در i امين موقعيت يک ليست (0≤ i ≤ n) درج يک قلم داده جديد در i امين موقعيت يک ليست (0≤ i < n). ( اقلام داده اي که قبلا به صورت i ، i+1 ،…،n-1 شماره گذاري شده اند به صورت i+1،i+2،…،n در مي آيند) حذف يک قلم اطلاعاتي از i امين موقعيت يک ليست (0≤ i < n) . اقلام داده i+1،…،n-1 به اقلام داده با شماره I،i+1،…،n-2 تبديل مي شود.

42 نگاشت ترتيبي نگاشت ترتيبي
متداول ترين پياده سازي ، نمايش يک ليست مرتب شده به صورت يک آرايه مي باشد به نحوي که عنصر ليست با انديکس i آرايه متناظر باشد. اين مطلب يک نگاشت ترتيبي ناميده مي شود.

43 ADT ماتريس اسپارس به طور کلي در رياضيات ، يک ماتريس شامل m سطر و n ستون بوده و مي تواند مانند شکل زير نمايش داده شود. 12 8 9 row 0 row 1 row 2 row 3 row 4 col1 col2 col3

44 ADT ماتريس اسپارس ماتريس اسپارس
در علوم کامپيوتر متداول ترين نمايش براي ماتريس آرايه دوبعدي است که به صورت a[MAX_ROW][MAX_COLS] نمايش داده مي شود. هر عنصر ماتريس به صورت a[i][j] نمايش داده مي شود. ماتريسي که عناصر صفر آن زياد بوده ماتريس اسپارس ناميده مي شود. حداقل اعمال ممکن شامل ايجاد، جمع ، ضرب و ترانهاده ماتريس مي باشد.

45 ADT ماتريس اسپارس مي توان هر آرايه را با استفاده از سه گانه ذخيره نمود اين بدان معنا مي باشد که مي توان يک آرايه از سه گانه ها را براي نمايش يک ماتريس اسپارس پيشنهاد کرد.

46 ترانهاده يک ماتريس براي پيدا نمودن ترانهاده يک ماتريس بايد جاي سطرها و ستون ها را عوض کرد بدين مفهوم که هر عنصر a[i][j] در ماتريس اوليه به عنصرb[j][i] در ماتريس ترانهاده تبديل مي شود. الگوريتم زير براي پيدا کردن ترانهاده يک ماتريس ، الگوريتم مناسبي است : for all element is column j place element < i ، j ،value> in element < j ، i ،value>

47 ترانهاده يک ماتريس الگوريتم بيان شده نشان مي دهد که بايد تمام عناصر در ستون 0 را پيدا و آنها را در سطر 0 ذخيره کرد همچنين تمام عناصر ستون 1 را پيدا و در سطر 1 قرار داد و همين فرآيند را ادامه داد. از آنجا که ماتريس اوليه سطري بوده لذا ستون هاي داخل هر سطر از ماتريس ترانهاده نيز به صورت صعودي مرتب مي شود.

48 تحليل ترانهاده تعيين زمان اجراي اين الگوريتم از آنجا که حلقه هاي تودرتوي for عامل تعيين کننده مي باشد ، آسان است. حلقه for خارجي a[0].col مرتبه تکرار مي شود که a[0].col حاوي تعداد ستون هاي ماتريس اوليه است. علاوه بر اين ، يک يک تکرار حلقه داخلي for به زماني برابر باa[0].value نياز دارد که در اينجا ، a[0].value تعداد عناصر در ماتريس اوليه است. بنابراين زمان کلي براي حلقه هاي تودرتوي for برابر با حاصل ضرب ستون ها در عناصر(columns.elements) مي باشد. بنابراين زمان اجرا به صورت 0(columns.elements) خواهد بود.

49 نکته : حاصل ضرب دو ماتريس اسپارس ممکن است يک ماتريس اسپارس نباشد.
ضرب ماتريس با توجه به ماتريس هاي مشخص و معلوم A وB ، فرض کنيد که A يک ماتريس m×n و B يک ماتريس m×p باشد آنگاه ماتريس حاصل ضرب D داراي ابعاد m×p است و عنصر <i،j> آن به صورت زير تعريف مي شود : براي 0 ≤ j < p و 0 ≤ i < m نکته : حاصل ضرب دو ماتريس اسپارس ممکن است يک ماتريس اسپارس نباشد.

50 روالmmult در روال mmult ماتريس هاي A وB را ضرب کرده و با توجه به
توضيحات حاصل ضرب را در D قرار مي دهيم. A ، B ، D به عنوان ماتريس هاي اسپارس به ترتيب در آرايه هاي A ، b ،d ذخيره مي شوند. زمان اين الگوريتم برابر با O(rows_a . Cols_a . cols_b)است

51 نمايش آرايه هاي چند بعدي
روش سطري دو راه متداول براي نمايش آرايه هاي چند بعدي وجود دارد : روش ستوني روش سطري در روش سطري آرايه هاي چند بعدي را به وسيله سطرهاي آن ذخيره مي کنيم. مثال آرايه دو بعدي نشان مي دهد که داراي سطر است به نحوي که هر سطر شامل عنصر مي باشد.

52 نمايش آرايه هاي چند بعدي
مثال اگرα آدرس A[0][0] باشد، بنابراين آدرس A[i][0] ، α+ i. Upper خواهد بود. براي نمايش يک آرايه سه بعدي ، آن را به عنوان آرايه دو بعدي با ابعاد در نظر مي گيريم.

53 نوع داده مجرد رشته اي(STRING ADT)
از ديدگاه ADT يک رشته به صورت تعريف مي گردد به نحوي که کاراکترهاي اخذ شده از مجموعه کاراکترهايزبان برنامه نويسي مي باشد. اگر n=0 باشد،S يک رشته تهي مي باشد. در زبان C ، رشته ها به صورت آرايه هاي کاراکتري که به کاراکترتهي، 0\،ختم مي شوند ،آرايه مي گردد.

54 نوع داده مجرد رشته اي(STRING ADT)
عملکردهاي مناسب و مفيدي وجود دارد که مي توان براي رشته ها تعريف کرد مانند : ايجاد يک رشته تهي جديد خواندن يا نوشتن يک رشته ضميمه کردن دو رشته به يکديگر (concatenation) کپي کردن يک رشته مقايسه رشته ها درج کردن يک زير رشته به داخل رشته برداشتن يک زير رشته از يک رشته مشخص پيدا کردن يک الگو(pattern) يا عبارت در يک رشته مختص ADT جديد

55 نوع داده مجرد رشته اي(STRING ADT)
نحوه ذخيره سازي در حافظه : char s[] = {"dog”{ ; s[0] s[1] s[2] s[3] \0 g o d نمايش رشته در زبان C

56 مثال : درج رشته مي خواهيم رشته t را در موقعيت رشته s جاي دهيم : s t
temp \0 e l i b o m a \0 o t u \0 initially temp \0 a (a) After strncpy(temp،s،i) temp \0 o t u a (b) After strcat(temp،t) temp \0 e l i b o m t u a

57 تطابق الگو(Pattern Matching)
فرض کنيد که دو رشته داريم ، string وpat، به نحوي pat يک الگو يا pattern بوده و بايد در string پيدا شود. ساده ترين راه براي تعيين اينکه آيا pat در رشته وجود دارد يا خير ، استفاده از تابع کتابخانه اي strstr مي باشد. با وجود اينکه strstr براي تطابق عبارت مناسب به نظر مي رسد ، دو دليل عمده براي نوشتن تابع تطابق الگو وجود دارد : تابع strstr براي ANSI C. جديد بوده و ممکن است که در کامپايلر موجود نباشد. چندين روش براي پياده سازي تابع تطابق الگو وجود دارد.

58 تطابق الگو نکته غير موثرترين روش ، تست متوالي هر کاراکتر رشته تا زمان پيدا شدن الگو و يا رسيدن به انتهاي رشته ، مي باشد. اگر pat در string نباشد، اين روش داراي زمان محاسباتي 0(n،m) خواهد بود که در آن n طول patوm طول string مي باشد.

59 فصل سوم : صف وپشته اهداف آشنايي با پشته آشنايي با صف ارزشيابي عبارات

60 فصل سوم : پشته و صف پشته و صف ، حالات خاصي از نوع داده عمومي يعني ليست هاي مرتب شده ، مي باشند. پشته پشته يک ليست مرتب شده اي است که جايگذاري و حذف از يک سمت آن که top (بالا) ناميده مي شود ، صورت مي گيرد. در پشته اي مانند ، عنصر پاييني و عنصر بالايي مي باشد.

61 پشته محدوديت کار با پشته ما را ملزم مي کند که اگر عناصر A،B،C،D،E را به ترتيب به پشته اضافه کنيم ، E اولين عنصري خواهد بود که که از پشته حذف مي گردد. از آنجا که آخرين عنصر وارده به پشته ، اولين عنصر حذف شده از آن مي باشد ، پشته را به عنوان يک ليست LIFO (آخرين ورودي ، آخرين خروجي ) مي شناسيم.

62 پشته حذف و جايگذاري عناصر در يک پشته ← top A B A C B A D C B A E D C B

63 ساختار نوع داده مجرد پشته
structure srack is objects: a fine ordered list with zero or more elements. functions: for all stack Stack ، item element ، max_stack_size positive integre Stack CreateS(max_stack_size)::= creat an empty stack whose maximume size is max_stack_size Boolean IsFull(stack،max_stack_size)::= if(number of elements in stack == max_stack_size) return TRUE else return FALSE Stack Add(stack،item)::= if (IsFull (stack)stack_full else insert item into top of stack and return Boolean IsEmpty (stack)::= if(stack ==Creat S( max_stack_size) Element Delete (stack)::= if (IsEmpty (stack)return else remove and return the item on the top of the stack

64 پياده سازي پشته راحت ترين روش پياده سازي اين ADT ، استفاده از يک آرايه يک بعدي به نام stack[MAX_STACK_SIZE] است که [MAX_STACK_SIZE] حداکثر تعداد عناصر آرايه مي باشد. اولين يا پايين ترين عنصر پشته درstack[0] ذخيره ، دومي در stack[1] و i امين عنصر در stack[i-1] ذخيره مي گردد.همراه با آرايه ، يک متغير به نام top وجود دارد که به عنصر بالايي پشته اشاره مي کند. در ابتدا به top مقدار 1- داده مي شود که نشان دهنده يک پشته خالي است. با اين نمايش ، مي توانيم عملکردهاي ساختار را به صورت زير پياده سازي کنيم :

65 پياده سازي پشته Stack CreatS(max_stack_size)::=
#define MAX_STACK_SIZE 100 /* maximume stack size*/ typedef struct { int key; /* other fields*/ }element; Element stack [MAX_STACK_SIZE]; int top = -1; Boolean IsEmpty(Stack)::=top<0; Boolean IsFull(Stack)::= top >= MAX_STACK_SIZE-1;

66 جايگذاري به يک پشته Void add (int *top ، element item) {
/* add an item to the global stack */ if (* top > = MAX_STACK_SIZE-1) { stack_full(); return; } stack [++*top] = item;

67 حذف از يک پشته element delete (int * top ) {
/* return the top element from the stack */ if (* top == -1) return stack _empty (); /* returns an error key */ return stack [( * top)--]; }

68 صف صف صف يک ليست مرتب شده است که تمامي جايگذاري آن از يک سمت و تمام حذف هاي ان از سمت ديگر انجام مي شود. درصف ، عنصر ابتدا (front) و عنصر انتها (rear) مي باشد و در کنار قرار دارد (0≤ i < n-1)

69 صف محدوديت صف اين است که ما A،B،C،D را به ترتيب اضافه مي کنيم در حالي که A اولين عنصري است که حذف مي شود. A B A C B A D C B A D C B ← rear ← rear ← rear ← rear ← rear ← front ← front ← front ← front ← front درج و حذف عناصر از يک صف

70 صف از آنجا که اولين وارد شده به يک صف ، اولين عنصري است که خارج
مي شود ، صف را به عنوان ليست هاي FIFO ( اولين ورودي، اولين خروجي ) در نظر مي گيرند.

71 جايگذاري در صف Void addq ( int * rear ، element item ) {
/* add an item to the queue */ if (* rear ==MAX_QUEUE _SIZE -1) { queue_full(); retyrn; } queue[++* rear] = item;

72 حذف عنصري از يک صف element deleteq (int *front ، int rear ) {
/* remove element at the front of the queue */ if (* front == rear ) return queue_empty (); /* return an error key */ return queue [==* front]; }

73 مساله مسير پر پيچ و خم (MAZING)
بهترين راه نمايش مسير فوق يک آرايه دو بعدي است که صفرهاي آن نشان دهنده پيچ و خم هاي مسير مي باشد. يک مسير پر پيچ و خم (maze) با ابعاد m×p به يک آرايه (m+2)×(p+2) نياز دارد. ورودي در موقعيت [1][1] و خروجي در موقعيت [m][p] مي باشد.

74 تحليل مسير اندازه مسير پرپيچ و خم (maze) زمان اجراي مسير را تعيين مي کند . از آنجا که هر موقعيت درون مسير بيش از يک بار مشاهده نمي شود ، بدترين حالت پيچيدگي الگوريتم به صورت 0(mp) مي باشد به نحوي که m و p تعداد سطرها و ستون هاي مسير است.

75 ارزشيابي عبارات در هر زبان برنامه سازي براي ارزيابي صحيح عبارات ، به هر عملگر اولويتي نسبت مي دهيم. حال در هر جفت پرانتز ، اول عملگرهايي که داراي اولويت بالاتر هستند ، ارزشيابي مي شوند .

76 اولويت عملگرها شکل مقابل نشان دهنده اولويت عملگرها در زبان c مي باشد.
Token () [] ->. -- ++ ! ~ - + & * Sizeof (type) * / % + - << >> >>= <<= = = != & ^ l && ll ?: = += -= *= %= <<= >>= &= ^= l= ، شکل مقابل نشان دهنده اولويت عملگرها در زبان c مي باشد.

77 روش infix روش استاندارد نوشتن عبارات به عنوان infix معرفي و
شناخته مي شود چرا که در اين روش عملگرهاي دودويي را در بين دو عملوند قرار مي دهيم.

78 ((a/(b-c+d))*(e-a)*c
نشانه گذاري postfix دراين روش هر عملگر بعد از عملوند هاي مربوطه ظاهر مي شود مثال Postfix Infix 2 3 4*+ ab*5+ 1 2+7* ab*c/ abc-d+/ea-*c* ab/c-de*+ac*- 2+3*4 a*b+5 (1+2)*7 a*b/c ((a/(b-c+d))*(e-a)*c a/b-c+d*e-a*c

79 خصوصيات postfix عبارات براي ارزيابي از چپ به راست پويش مي شوند. عملوندها تا مشاهده يک عملگر، داخل پشته قرار مي گيرند، سپس تعداد لازم از عملوندها را از پشته خارج و پس از انجام عملکرد مربوطه ، نتيجه را دوباره به داخل پشته منتقل مي کنيم . اين کار را ادامه پيدا مي کند تا به انتهاي عبارت برسيم.

80 الگوريتم تبديل infix به postfix
1- پرانتزگذاري کامل عبارات 2- انتقال همه عملگرهاي دودويي به نحوي که با پرانتز بسته مربوطه سمت راست آن تعويض شوند 3- حذف تمام پرانتزها

81 مثال تبديل عبارت a+b*c به نشانه گذاري postfix Output Top Stack
[0] [1] [2] Token a ab abc abc*+ -1 1 + * b * c eos

82 مثال تبديل a*(b+c)*d به نشانه گذاري postfix Output Top Stack
[0] [1] [2] Token a ab abc abc+ abc+* abc+*d abc+*d* -1 1 2 * * ( * ( ( b + c ) d eos

83 تحليل postfix فرض کنيد n تعداد نشانه ها در عبارت باشد ، براي خارج ساختن نشانه ها و انتقال آنها به خروجي نياز به Θ(n) مي باشد. بنابراين پيچيدگي تابع postfix به صورت Θ(n) خواهد بود.

84 فصل چهارم: ليست ها اهداف آشنايي با اشاره گر ها ليست ها و ليست حلقوي
روابط هم ارزي ليست پيوندي دوگانه

85 ويژگي هاي نمايش ساختمان داده ها با استفاده از آرايه و نگاشت ترتيبي:
فصل چهارم : ليستها ويژگي هاي نمايش ساختمان داده ها با استفاده از آرايه و نگاشت ترتيبي: خاصيت اين نحوه نمايش آن بود که عناصر پشت سرهم داده مقصود با فواصل ثابت و معيني ذخيره مي شدند. بنابراين : اگرi امين عنصر صف در موقعيت باشد، (i+1) امين عنصر، در نمايش حلقوي در موقعيت+c)%MAX_QUEUE_SIZE ( قرار خواهد گرفت . اگر بالاترين عنصر پشته در مکان باشد، پايين ترين عنصر در مکان خواهد بود.

86 مشکلات نمايش ترتيبي 1- حذف و درج عناصر در آرايه ها بسيار وقت گير است
2- وقتي داراي چندين ليست مرتب شده با طول هاي متفاوت هستيم. باذخيره کردن هر ليست در آرايه اي با حداکثر اندازه ، حافظه هدر مي رود 3- با نگهداري ليستها در يک آرايه ، انتقال حجم زيادي از داده ها لازم است.

87 نمايش پيوندي راه حل مناسب براي حل مشکل شيفت داده ها در نگاشت ترتيبي ، استفاده از نمايش پيوندي مي باشد. بر خلاف نمايش ترتيبي که عناصر در فواصل ثابتي از هم قرار مي گرفتند، در ليست پيوندي عناصر مي توانند در هر جاي حافظه قرار گيرند. براي دستيابي صحيح به عناصر يک ليست ، بايستي به همراه هر عنصر، آدرس يا موقعيت عنصر بعدي نيز ذخيره شود. بنابراين براي هر عنصر ، اشاره گري به عنصر بعدي در ليست وجود دارد.

88 اشاره گرها مهمترين عملگرهاي استفاده شده با نوع اشاره گر عبارتند از :
& عملگر آدرس * عملگر غيررجوعي(indirection or dereferencing) مثال int i ، * pi ; آنگاه i يک متغير صحيح و pi يک اشاره گر به يک متغير صحيح است. pi = &i ; &i آدرس i را برگشت و به ان مقدار pi را نسبت مي دهد.

89 خطر استفاده از اشاره گرها
در هنگام برنامه نويسي به زبان C بهتر است که تمام اشاره گرهايي را که عملا به جايي اشاره نمي کنند را برابر NULL قرار دهيم. اين عمل از تلاش براي دستيابي به قسمتي از حافظه که خارج از دامنه برنامه شما بوده و يا شامل اشاره گري به يک داده مقصود قابل دسترسي نيست ، جلوگيري مي کند.

90 استفاده از حافظه پويا( استفاده ازheap)
در يک برنامه ممکن است خواسته باشيم فضاي لازم براي ذخيره کردن اطلاعات را در نظر بگيريم. هنگام برنامه نويسي ممکن است ندانيم چه ميزان فضا لازم داشته يا نخواسته باشيم فضاي بسيار زيادي که احتمال دارد استفاده نشود را تخصيص دهيم، براي حل اين مشکل ، زبانC در زمان اجرا از مکانيزمي به نام heap براي تخصيص حافظه استفاده مي کند.

91 استفاده از حافظه پويا( استفاده ازheap)
هر زمان که نياز به حافظه جديدي باشد ، مي توان تابعي به نام malloc را فراخواني و مقدار فضاي لازم را درخواست کرد. اگر حافظه لازم وجود داشته باشد ، اشاره گري به ابتداي ناحيه حافظه مورد نياز برگردانده مي شود. زماني که ديگر نيازي به آن حافظه نباشد ، مي توان آن را با فراخواني تابعي به نام free ، آزاد نمود.

92 ليست هاي تک پيوندي ليست هاي پيوندي معمولا به وسيله گره هايي متوالي با اتصالاتي که به صورت فلش هايي نشان داده شده اند ارايه مي گردند. از نام اشاره گر به اولين عنصر ليست به عنوان نام کل ليست استفاده مي شود. بنابراين ليست شکل زير ptr ناميده مي شود.

93 ليست هاي پيوندي روش معمول براي نمايش يک ليست پيوندي bat . cat . sat . vat NULL ptr نکات گره ها واقعا در مکانهاي پشت سر هم حافظه قرار نمي گيرند (2) موقعيت گره ها در اجراهاي مختلف مي تواند تغيير کند

94 مثال مراحل درج کلمه mat بين cat و sat به صورت زير است :
1- گره اي را که اخيرا استفاده نشده در نظر گرفته ، فزض کنيد که آدرس آن paddr باشد. 2- فيلد داده اين گره را برابر با mat قرار دهيد 3- فيلد اتصال paddr را طوري تنظيم کنيد که به ادرسي که در فيلد اتصال گره حاوي cat مي باشد، اشاره کند 4- فيلد اتصال گره حاوي cat را طوري تنظيم کنيد که به paddr اشاره کند.

95 مثال(درج گره mat بعد از cat)
bat . cat . sat . vat NULL ptr mat .

96 حذف mat از ليست براي انجام اين کار فقط لازم است که عنصر قبل از mat يعني cat را پيدا و فيلد اتصال آنرا طوري تنظيم کنيم که به گره اي اشاره کند که در حال حاضر اتصال گره mat به ان اشاره دارد( شکل زير ) bat . cat . sat . vat NULL ptr mat .

97 امکانات لازم براي ايجاد ليست پيوندي
مکانيزمي براي تعريف ساختار گره ها يعني فيلدهايي که در گره وجود دارد روشي براي ايجاد گره هايي که مورد نياز مي باشد روشي براي آزاد کردن گره هايي که ديگر مورد نياز نمي باشد

98 چاپ يک ليست Void print_ list (list_pointer ptr) {
print f (" The list contains: " ); for ( ; ptr ; ptr = ptr -> link) print f (" %4d " ، ptr ->data); print f (" \ n " ); }

99 صف و پشته پيوندي پشته پيوندي صف پيوندي … … rear top element link front
. NULL link element صف پيوندي front . NULL link element rear

100 تابع add و delete توابع add و delete عناصري را به پشته اضافه و از آن حذف مي کنند. کد کردن هر يک از اين توابع ، کار ساده اي مي باشد. در هر دو تابع آدرس top را به گونه اي تغيير مي دهيم که به عنصر بالايي پشته اشاره کند. تابعadd تابع add يک گره جديد به نام temp ايجاد نموده ، item را در فيلد داده و top را در فيلد اتصال قرار مي دهد سپس متغير top براي اشاره کردن به temp تغيير مي کند

101 تابع delete تابع delete
تابع delete ، عنصر را برگشت و top را عوض مي کند تا به آدرسي که در فيلد اتصال آن قرار دارد ، اشاره کند سپس گره حذف شده به حافظه سيستم برگشت داده مي شود.

102 تابع اضافه کردن به يک پشته پيوندي
Void add (stack_pointer * top ، element item) { /* add an element to the top of the stack */ stack _pointer temp = (stack_pointer ) malloc (sizeof (stack)); if (IS_FULL(temp )) { fprint f (stderr ، " The memory is full \ n"); exit(1); } temp - > item = item ; temp - > link = * top ; * top = temp ;

103 حذف از يک پشته پيوندي element delete (stack_pointer * top ){
/* delete an element from the stack */ stack_pointer temp = * top ; element item ; if (IS_EMPTY (temp)) { fprintf ( stderr ، " The stack is empty \ n"); exit(1); } item = temp - >item ; * top = temp - > link ; Free (temp) ; return item ;

104 اضافه کردن گره اي به انتهاي يک صف پيوندي
Void addq (queue_pointer * front ، queue_pointer *rear ، element item) { /* add an element to the rear of the queue */ queue _pointer temp = (queue_pointer ) malloc (sizeof (queue )); if (IS_full (temp)) { fprint f (stderr ، " The memory is full \ n"); exit(1); } temp - > item = item ; temp - > link = NULL ; if (* front ) (* rear ) - > link = temp ; else * front = temp ; * rear = temp ;

105 حذف از ابتداي يک صف پيوندي
element deleteq (queue_pointer * front ) { /* delete an element from the queue */ queue_pointer temp = * front ; element item ; if (IS_EMPTY (* front )) { fprintf ( stderr ، " The queue is empty \ n"); exit(1); } item = temp - >item ; * front = temp - > link ; free (temp) ; return item ;

106 نمايش چند جمله اي ها به صورت ليست هاي تک پيوندي
در اينجا مي توان هر جمله را به صورت يک گره نمايش داد. در اين ارتباط هر گره داراي سه فيلد براي نمايش ضريب ، توان و اشاره گري به گره بعدي مي باشد. مثال 3 14 . 2 8 1 NULL a

107 جمع چند جمله اي براي جمع دو چند جمله اي ، ابتدا فرض مي کنيم که a و b اشاره گري به ابتداي چند جمله اي ها مي باشند. اگر توان دو چند جمله اي با هم برابر باشد ، ضرايب با هم جمع مي شوند و گره جديدي تشکيل مي شود ، همچنين اشاره گرها را به گره هاي بعدي در a و b حرکت مي دهيم. اگر توان چند جمله اي a کمتر از توان متناظر در چند جمله اي b باشد، آنگاه يک جمله شبيه به اين جمله ايجاد و آنرا به نتيجه ، يعني d ، اضافه مي کنيم و اشاره گر را به جمله بعدي در b منتقل مي کنيم. همين عمل را اگر a-> expon >b- > expon باشد بر روي a انجام مي دهيم .

108 تحليل جمع چند جمله اي ها براي محاسبه زمان لازم اجراي جمع چند جمله اي ، اولين نکته تعيين عملياتي است که بر زمان اجرايي اثر مي گذارد. جمع ضرايب مقايسه توان ها ايجاد گره جديد براي d براي اين الگوريتم بايد سه معيار در نظر گرفته شود : الگوريتم جمع چند جمله اي با فاکتور ثابت بهينه است.

109 رابطه هم ارزي رابطه ≡ روي هر مجموعه S ، رابطه هم ارزي گفته مي شود اگر داراي خواص انعکاسي ، تقارن و تعدي روي S باشد. مثال " تساوي" (=) ، يک رابطه هم ارزي است زيرا : x = x (1) است . x = y (2) تصريح مي کند که y = x مي باشد x = u (3) و y = z نتيجه مي دهد که x = z است .

110 الگوريتم تعيين کلاس هاي هم ارزي
الگوريتم تعيين کلاس هاي هم ارزي ، دو مرحله است : در مرحله اول ، زوج هاي هم ارزي <i ،j> ، را خوانده و ذخيره مي کند. در مرحله دوم از 0 شروع کرده و تمام زوج هاي که به شکل < 0 ، J > مي باشد ( به نحوي که 0 و j در يک کلاس هم ارزي مي باشند ) را پيدا مي کند.

111 الگوريتم هم ارزي بر اساس خاصيت تعدي همه مقادير به شکل < j ، k > با k در يک کلاس قرار مي گيرند. فضاي لازم براي اين الگوريتم 0(m + n ) است

112 نمايش ماتريس هاي اسپارس به وسيله ليست پيوندي
در نمايش داده ها ، هر سطر و ستون ماتريس اسپارس با يک ليست پيوندي حلقوي با گره head ارايه مي شود. هر گره داراي يک فيلد برچسب (tag) خواهد بود که وجه تمايز بين گره هاي head و گره هايي که عناصر مخالف صفر را ذخيره مي کنند ، مي باشد. هر گره head داراي سه فيلد ديگر نيز مي باشد : down ، right، next هر گره وارده داراي پنج فيلد ديگرمي باشد : value ، right ، down ، col، row

113 نمايش ماتريس هاي اسپارس به وسيله ليست پيوندي
از فيلد down براي اشاره به عنصر مخالف صفر بعدي در همان ستون از فيلد right براي اشاره به عنصر مخالف صفر بعدي در همان سطر استفاده مي شود. هر گره head در سه ليست قرار مي گيرد : ليست سطرها ليست ستون ها ليست گره هاي head

114 نمايش ماتريس هاي اسپارس به وسيله ليست پيوندي
اگر بخواهيم يک ماتريس اسپارس num_rows.num_cols با num_terms عنصر مخالف صفر را نمايش دهيم ، تعداد گره ها max { num_rows ،num_cols } + num_terms+1 خواهد بود.

115 ليست هاي پيوندي دوگانه ليست هاي تک پيوندي تنها بعضي از مشکلات را حل مي کند چرا که فقط به راحتي مي توانيم در جهت پيوندها حرکت کنيم. مثال فرض کنيد که به يک گره مشخص مانند ptr ، اشاره کنيم و بخواهيم گره قبل از ptr را پيدا کنيم ، تنها راه يافتن گره ماقبل ptr پيمايش از ابتداي ليست مي باشد.

116 ليست هاي پيوندي دوگانه يک گره در يک ليست پيوندي دوگانه حداقل داراي سه فيلد مي باشد : فيلد data فيلد llink (اشاره گر به چپ ) فيلد rlink ( اشاره گر به راست )

117 ليست هاي پيوندي دوگانه حلقوي يک ليست پيوندي دوگانه به دو صورت است :
غير حلقوي Head Node l link item r link يک ليست پيوندي دوگانه به دو صورت است : ليست پيوندي دوگانه حلقوي با گره head درج و حذف از يک ليست پيوندي دوگانه بسيار ساده مي باشد.

118 درج دريک ليست پيوندي دوگانه حلقوي
Void dinsert ( node_pointer node ، node_pointer newnode ) { /* insert newnode to the right of node */ newnode-> llink = node ; newnode-> llink = node-> r link ; node -> r link -> l link = newnode; node -> r link = newnode ; }

119 حذف از يک ليست پيوندي دوگانه حلقوي
Void delete ( node_pointer node ، node_pointer deleted ) { /* delete from the doubly linked list */ if (node = = deleted ) print f (" Deletion of head node not permitted .\ n " ) else { deleted -> l link - > r link = deleted - > r link ; deleted -> r link - > l link = deleted - > l link ; free ( deleted) ; }

120 فصل پنجم : درخت اهداف آشنايي با درخت درخت هاي دودويي پيمايش درختان هرم
جنگل

121 فصل پنجم : درختان درخت ساختار درختي يعني مجموعه داده هاي سازماندهي شده اي که عناصر اطلاعاتي شان به وسيله انشعاباتي با هم رابطه داشته باشند.

122 مفهوم درخت درخت مجموعه محدودي از يک يا چند گره به صورت زير مي باشد :
داراي گره خاصي به نام ريشه باشد. بقيه گره ها به n ≥ 0 مجموعه مجزا تقسيم شده که هر يک از اين مجموعه ها خود يک درخت هستند. زير درختان ريشه ناميده مي شوند.

123 مثالي از يک درخت درجه A = 3 شکل1-5
C G D B E H I J M F ريشه درخت L K همزاد درجه A = 3 شکل1-5 A والد B ، C، D است . B ، C، D همزادند.

124 اصطلاحات درخت ها گره : گره به عنصر حاوي اطلاعات و انشعابات به ديگر عناصر ، اطلاق مي شود. درجه گره : تعداد زير درخت هاي يک گره را درجه آن گره مي نامند. والد : گره اي که داراي زير درختاني است را والد ريشه هاي زير درختان گويند . فرزندان گره : ريشه هاي زير درختان ، فرزندان آن گره ناميده مي شوند.

125 اصطلاحات درخت ها گره هاي همزاد :فرزندان يک گره ، گره هاي همزاد يا هم نيا ناميده مي شوند. اجداد گره : اجداد يک گره ، گره هايي هستند که در مسير طي شده از ريشه تا آن گره وجود دارند. سطح گره : سطح يک گره بدين صورت تعريف مي شود که ريشه در سطح يک قرار مي گيرد. براي تمامي گره هاي بعدي ، سطح گره برابر است با سطح والد به اضافه يک . ارتفاع درخت : ارتفاع يا عمق يک درخت به بيشترين سطح گره هاي آن درخت گفته مي شود.

126 نمايش ليست يک راه نمايش درخت ، استفاده از ليست است .
شکل 1-5 را مي توان به صورت زير نشان داد : (A(B(E(K ،L)،F)،C(G)،D(H(M)،I،J)))

127 نمايش ليست ممکن براي درختان
شکل زير يک ساختار ممکن براي نمايش ليست را نشان مي دهد : Link n link 2 link 1 data

128 نمايش دودويي يک درخت براي نمايش درختان دودويي ، دقيقا نياز به دو اتصال يا اشاره گر به ازاي هر گره است. Data right sibling left child

129 2-5 درخت هاي دودويي تعريف :
يک درخت دودويي يا تهي است يا حاوي مجموعه اي محدود از گره ها شامل يک ريشه و دو زير درخت دودويي است. اين درخت ها زير درخت هاي چپ و راست ناميده مي شوند. مشخصه اصلي يک درخت دودويي بدين شکل است که هر گره آن حداکثر دو انشعاب دارد يعني گره هايي که درجه اي بيشتر از دو نداشته باشند. براي درخت هاي دودويي زير درخت سمت چپ و راست با يکديگر متمايز است.

130 2-5 ساختار درخت دودويي structure Binary_tree (abbreviated BinTree ) is
objects : a finite set of nodes either empty or consisting of a root node ، left Binary_tree ، and right Binary_tree. functions : for all bt ، bt1 ، bt2 BinTree ، item element BinTree Create() Boolean IsEmpty (bt) BinTree MakeBT(bt1 ، item ، bt 2) BinTree Lchild(bt) element Data(bt) BinTree Rchild(bt)

131 2-5 تفاوت درخت عادي با درخت دودويي
در هيچ درخت عادي صفر گره وجود ندارد ، اما درخت دودويي تهي وجود دارد. در يک درخت دودويي ترتيب فرزندان داراي اهميت بوده در حالي که در درخت عادي به اين صورت نيست.

132 2-5 خواص درختان دودويي حداکثر تعداد گره ها
حداکثر تعداد گره ها در سطح i ام يک درخت دودويي است ، i ≥ 1 . حداکثر تعداد گره ها در يک درخت دودويي به عمق k ، است ، k ≥ 1

133 رابطه بين تعداد گره هاي برگ و گره هاي درجه 2
2-5 خواص درختان دودويي رابطه بين تعداد گره هاي برگ و گره هاي درجه 2 براي هر درخت دودويي غير تهي مانند T ، اگر تعداد گره هاي پاياني و تعداد گره هاي درجه 2 باشد ، آنگاه خواهيم داشت :

134 2-5 خواص درختان دودويي يک درخت دودويي پر به عمق k ، يک درخت دودويي است که داراي گره باشد k ≥ 0 . يک درخت دودويي با n گره و عمق k کامل است ، اگر و تنها اگر گره هايش مطابق با گره هاي شماره گذاري شده در يک درخت دودويي پر به عمق k باشد.

135 2-5 نمايش درخت دودويي نمايش آرايه نمايش ليست
نمايش درخت دودويي به دو صورت است :

136 2-5 نمايش آرايه شيوه شماره گذاري ارايه شده در شکل زير ، اولين نمايش يک درخت دودويي در حافظه را مطرح و پيشنهاد مي کند . از آنجايي که گره ها از 1 تا n شماره گذاري شده اند ، يک آرايه يک بعدي مي تواند براي ذخيره سازي گره ها استفاده شود .

137 نمايش آرايه اي درخت دودويي
2-5 نمايش آرايه A C B D F G E I H [1] [2] [3] [4] [5] [6] [7] [8] [9] . [16] A B - C D . E نمايش آرايه اي درخت دودويي

138 2-5 نمايش آرايه اگر يک درخت دودويي کامل با n گره ( يعني عمق ) به
ترتيب بالا تعريف شده باشد ، آنگاه براي هر گره با انديس i و ≤ n i 1≤ ، داريم : اگر i≠1 ، آنگاه پدر i در [i/2] است . اگر i=1 ، i ريشه است و پدري نخواهد داشت. (2) اگر2i≤n ، آنگاه فرزند چپ i در 2i است. اگر 2i>n ، آنگاه i فرزند چپ ندارد. (3) اگر 2i+1≤n ، آنگاه فرزند راست i در 2i+1 است. اگر 2i+1>n ، آنگاه i فرزند راست ندارد

139 2-5 نمايش آرايه در بدترين حالت ، يک درخت مورب به عمق k ، به محل و موقعيت نياز دارد که از اين مقدار، فقط k محل اشغال مي شود.

140 2- 5 نمايش ليست پيوندي ماداميکه نمايش ترتيبي (آرايه اي) براي درختان دودويي کامل مناسب به نظر مي رسد ، ما براي بسياري از درختان ديگر باعث اتلاف حافظه مي شود به علاوه ، اين روش از نارسايي هاي موجود در نمايش ترتيبي نيز برخوردار است. درج يا حذف گره هاي يک درخت ، مستلزم جابه جايي گره هاست که خود باعث تغيير شماره سطح گره ها مي شود. اين مسايل مي تواند با به کارگيري نمايش پيوندي به آساني حل شود.

141 2-5 نمايش ليست پيوندي با اين روش هر گره سه فيلد خواهد داشت :
left_child ، data ، right_child که در زبان C به شرح زير تعريف مي شوند : typedef struct node *tree_pointer ; typedef struct node { int data ; tree_pointer left_child ، right_child ; };

142 2-5 نمايش ليست پيوندي نمايش يک گره درخت دودويي right_child data
left_child data right_child right_child data left_child نمايش يک گره درخت دودويي

143 3-5 پيمايش درخت دودويي به هنگام پيمايش يک درخت دودويي ، با هر گره و زيردرختانش به طرز مشابهي رفتار کنيم. اگر R ، V ، L به ترتيب حرکت به چپ ، ملاقات کردن يک گره ( براي مثال ، چاپ فيلد داده آن گره) و حرکت به راست باشد، آنگاه شش ترکيب ممکن براي پيمايش يک درخت خواهيم داشت : RLV ، RVL ، VRL ، VLR ، LRV ، LVR

144 3-5 پيمايش درخت دودويي مثال
اگر تنها حالتي را انتخاب کنيم که ابتدا به سمت چپ و بعد به سمت راست برود ، تنها سه ترکيب VLR ، LRV ، LVR خواهيم داشت. اين سه حالت را با توجه به موقعيت V نسبت به L و R به ترتيب preordcr ، postorder ، inorder مي ناميم.

145 3-5 پيمايش درخت دودويي در پيمايش postorder ، يک گره موقعي ملاقات و چاپ مي شود که زيردرختان چپ و راست آن قبلا ملاقات شده باشند. در پيمايش preorder ، يک گره قبل از پيمايش زيردرختان چپ و راست ، ملاقات مي گردد.

146 3-5 پيمايش درخت دودويي درخت زير حاوي يک عبارت رياضي است : A/B*C*D*+E
1 2 3 4 5 6 7 9 10 8 11 14 17 19 18 16 15 13 12 درخت دودويي براي يک عبارت محاسباتي

147 3-5 پيمايش Inorder هنگامي که اين پيمايش انتخاب مي شود ، حرکت به سمت پايين به طرف چپ انجام مي شود و اين عمل تا آخرين گره صورت مي گيرد سپس مي توان گره را بازيابي کرد و بعد به سمت راست رفته و به همين ترتيب کار را ادامه پيدا مي کند. اين متناظر با شکل infix يک عبارت است.

148 3-5 پيمايش Inorderيک درخت دودويي
Vide inorder (tree_pointer ptr ) /* inorder tree traversal */ { if (ptr) { inorder ( ptr -> left_child ); printf (“ % d” ، ptr -> data ); inorder (ptr -> right_child); }

149 3-5 پيمايش Preorder تابع preorder حاوي دستورات لازم براي شکل دوم پيمايش است. بر اساس اين پيمايش ، گره را ابتدا بازيابي و ملاقات نموده و سپس انشعابات چپ را دنبال و تمام گره ها را بازيابي مي کنيم. اين فرآيند ادامه پيدا مي کند تا به يک گره تهي برسيم. در اين نقطه ، به نزديکترين جدي که داراي يک فرزند راست باشد مراجعه و با اين گره شروع خواهيم نمود.

150 3-5 پيمايش Preorder با پيمايش preorder گره هاي درخت زير خروجي به شکل زير خواهند داشت : + E * D C / A B 1 2 3 4 5 6 7 9 10 8 11 14 17 19 18 16 15 13 12 خروجي + * * / A B C D E اين به شکل يک عبارت prefix است.

151 3-5 پيمايش Preorder يک درخت دودويي
Vide preorder (tree_pointer ptr ) /* preorder tree traversal */ { if (ptr) { printf (“ % d” ، ptr -> data ); preorder ( ptr -> left_child ); preorder (ptr -> right_child); }

152 3-5 پيمايش postorder اين پيمايش دو فرزند يک گره را قبل از بازيابي آن گره ملاقات و چاپ مي کند. اين مساله بدين مفهوم است که فرزندان يک گره قبل از خود آن گره بازيابي مي گردد.

153 3-5 پيمايش postorder خروجي حاصل از پيمايش postorder شکل زير به صورت زير است : + E * D C / A B 1 2 3 4 5 6 7 9 10 8 11 14 17 19 18 16 15 13 12 خروجي A B/ C* D* E + اين خروجي مانند يک عبارت postfix است.

154 3-5 پيمايش inorder غيربازگشتي
Void iter_pointer (tree_pointer node ) { int top = -1 ; /* initialize stack */ tree_pointer stack [MAX_STACK_SIZE] ; for ( ; ; ) { for (; node ; node = ->left_child) add ( &top ، node ); /* add to stack */ node = delete (&top); /*delete from stack */ if (! Node) break ; /* empty stack*/ printf (“ % d”، node-> data ) ; node = node -> right_child; }

155 3-5 پيمايش inorder غيربازگشتي
تحليل inorder2 : فرض کنيد تعداد گره هاي درخت n باشد ، اگر عمل iter_inorder را در نظر بگيريم ، مشاهده مي شود که هر گره درخت فقط يک بار در پشته قرار گرفته و يا از آن خارج مي شود. بنابراين اگر تعداد گره هاي درخت n باشد ، پيچيدگي زمان تابع برابر با O(n) مي باشد. حافظه مورد نياز برابر با عمق درخت است که مساوي با O(n) مي باشد.

156 3-5 پيمايش ترتيب سطحي پيمايش هاي inorder ، preorder ، postorder چه به صورت بازگشت پذيري نوشته يا به صورت غيربازگشتي ، همگي نيازمند پشته مي باشند. اين پيمايش ، ترتيب سطحي ، ابتدا ريشه را بازيابي ، سپس فرزند چپ ريشه و به دنبال آن فرزند راست ريشه بازيابي مي گردد. اين شيوه با بازيابي از گره منتهي اليه سمت چپ به سمت راست هر سطح جديد تکرار مي گردد. اين پيمايش از صف استفاده مي کند.

157 3-5 پيمايش ترتيب سطحي پيمايش ترتيب سطحي درخت زير به صورت زير است :
+ E * D C / A B 1 2 3 4 5 6 7 9 10 8 11 14 17 19 18 16 15 13 12 + *E *D / C A B

158 4-5 اعمال مفيد بر روي درختان دودويي
1- کپي کردن درختان دودويي 2- تعيين برابري و تساوي دو درخت 3- مساله Satisfiability

159 5-5 درختان نخي دودويي تعداد اتصالات تهي در يک درخت دودويي بيشتر از تعداد اشاره گرهاي غيرتهي است. در يک درخت دودويي تعداد n + 1 اتصال از کل اتصالات آن يعني ، 2n تهي است. يک راه براي به کارگيري اين اتصالات توسط پرلين و تورنتن پيشنهاد شد. راه حل اين بود که از اتصالات تهي براي ارتباط با ديگر گره هاي يک درخت استفاده شود که در اين صورت درخت را درخت نخي مي نامند.

160 5-5 درختان نخي دودويي براي ايجاد اتصالات نخي از قوانين زير استفاده مي شود : اگر ptr-> left_child تهي باشد ، آن را طوري تغيير مي دهيم که به گره اي که در پيمايش inorder قبل از ptr قرار دارد ، اشاره کند. اگر ptr-> right_child تهي باشد ، آن را طوري تغيير مي دهيم که به گره اي که در پيمايش inorder بعد از ptr قرار دارد ، اشاره کند.

161 5-5 درختان نخي دودويي هنگامي که درختي را در حافظه نمايش مي دهيم ، بايستي بتوانيم بين اتصالات نخي و واقعي تفاوتي قايل شويم. اين کار را با افزودن دو فيلد اضافي به هر گره انجام مي دهيم که آنها را right_thread ، left_thread مي ناميم.

162 5-5 درختان نخي دودويي درخت نخي متناظر اتصالات نخي A C B D F G E I H A

163 5-5 پيمايش inorder يک درخت نخي دودويي
براي هر گره مانند ptr ، در يک درخت دودويي ، چنانچه ptr->right_thread = TRUE باشد ، طبق تعريف گره بعدي ptr در پيمايش inorder ، ptr->right_child مي باشد . در غير اين صورت گره بعدي ptr، با پايين رفتن روي مسير فرزندان چپ ptr از طرف فرزند سمت راست ptr تا وقتي که به گره اي با وضعيت left_thread = TRUE برسيم ، تعيين مي شود .

164 5-5 پيمايش inorder يک درخت نخي دودويي
تابع insucc بدون استفاده از پشته ، گره بعدي در پيمايش inorder را در يک درخت نخي دودويي پيدا مي کند. براي پيمايش inorder مي توانيم با فراخواني مکرر insucc تمام گره ها را بازيابي کنيم .

165 5-5 پيمايش inorder يک درخت نخي دودويي
تابع insucc : threaded_pointer insucc (threaded_pointer tree) { /* find the inorder sucassor of tree in a threaded binary tree */ threaded_pointer temp ; temp = tree -> right_child ; if (! Tree -> right_thread) while (! temp -> left_thread) temp = temp -> left_child ; return temp ; } پيدا نمودن گره بعد ، يک گره خاص در پيمايش inorder

166 5-5 پيمايش inorder يک درخت نخي دودويي
Void tinorder (threaded_pointer tree) { /* traverse the threaded binary tree inorder */ threaded_pointer temp = tree ; for ( ; ; ) { temp = insucc (temp) ; if (temp = tree ) break ; printf (“ % 3c” ، temp -> data ) ; }

167 5-5 درج يک گره به داخل درخت نخي دودويي
فرض کنيد داراي گرهي به نام parent هستيم که داراي زيردرخت راست تهي مي باشد ، آنگاه مايل هستيم child را به عنوان فرزند راست parent درج کنيم . براي انجام اين کار بايد : parent->right_thread را برابر FLASH قرار دهيد. child-> left_thread و child-> right_thread را برابر TRUE قرار دهيد . child-> left_child را طوري تنظيم کنيد که بهparen اشاره کند. child-> right_child را برابر parent->right_child قرار دهيد. parent->right_child را طوري تنظيم کنيد که به childاشاره کند.

168 5-5 درج يک گره به داخل درخت نخي دودويي
مثال در شکل زير گره D را به عنوان فرزند راست گره B جايگذاري مي کنيم : A B C root parent D child

169 6-5 نوع داده مجرد ( (ADTهرم
max tree درختي است که مقدار کليد هر گره آن کمتر از مقادير کليدهاي فرزندانش نباشد. max heap يک درخت دودويي کامل است که يک max tree نيز مي باشد. min tree درختي است که مقدار کليد هر گره آن بيشتر از مقادير کليدهاي فرزندانش نباشد. min heap يک درخت دودويي کامل است که در واقع يک min tree مي باشد.

170 6-5 مثال از max heap و min heap
14 7 12 10 8 [1] [2] [4] [5] [3] 6 [6] 9 3 6 5 [1] [2] [4] [3] مثال از max heap 2 4 7 10 8 [1] [2] [4] [5] [3] 6 [6] 10 83 20 50 [1] [2] [4] [3] مثال از min heap

171 6-5 اعمال اساسي بر روي heap

172 6-5 صف اولويت غالبا هرم ها براي پياده سازي صف اولويت ها استفاده مي شوند. در صف اولويت ها عنصري که داراي بالاترين ( يا پايين ترين ) اولويت هست ، حذف مي شود. آرايه ساده ترين نمايش براي يک صف اولويت مي باشد.

173 6-5 نمايش هاي صف اولويت Deletion Insertion Representation Θ(n) Θ(1)
Unordered array Θ(n Unordered linked list O(n) Stored array Stored linked list Max heap

174 6-5 درج عناصر به داخل يک Max Heap
20 2 15 14 [1] [2] [4] [3] 10 [5] 20 2 15 14 [1] [2] [4] [3] 10 [5] درج عنصر جديد ب - محل اوليه گره جديد الف - درخت heap قبل از درج اضافه کردن گره جديد در هر موقعيت ديگري ،تعريف heap را نقض مي کند زيرا نتيجه يک درخت دودويي کامل نخواهد بود.

175 6-5 درج عنصر به يک Max heap Void insert_max_heap ( element item ، int *n ) { /* insert item into a max heap of current size *n * / int i ; if (HEAP_FULL(*n) { fprint f (stderr ، “ The heap is full . \n”) ; exit (1) ; } i = ++ ( *n ) ; while (( i ! = 1 ) && (item.key > heap [i/2] . Key )) { heap [i] = heap[i/2] ; i / = 2 ; heap [i] = item ;

176 6-5 تحليل تابع insert_max_heap
از آنجا که heap يک درخت کامل با n عنصر مي باشد ، داراي ارتفاع مي باشد. اين بدين معني مي باشد که حلقه while به ميزان تکرار شود. بنابراين پيچيدگي تابع درج برابر مي باشد.

177 6-5 حذف عنصري از Max Heap هنگامي که عنصري از max heap حذف مي شود ، آن را از ريشه درخت heap مي گيريم. 2 15 14 [1] [2] [4] [3] [5] 20 removed 20 2 15 14 [1] [2] [4] [3] 10 [5] حذف يک عنصر از max heap

178 6-5 تحليل تابع delete_max_heap
پيچيدگي حذف برابر مي باشد. زمان حذف يک عنصر دلخواه از درخت heap با n عنصر ، برابر O(n) مي باشد.

179 7-5 درختان جستجوي دودويي يک درخت جستجوي يک درخت دودويي است که ممکن است تهي باشد. اگر درخت تهي نباشد خصوصيات زير را برآورده مي کند : هر عنصر داراي يک کليد است و دو عنصر نبايد داراي کليد يکسان باشند ، در واقع کليدها منحصر به فردند. کليدهاي واقع در زيردرخت غيرتهي چپ بايد کمتر از مقدار کليد واقع در ريشه زيردرخت راست باشد. کليدهاي واقع در زيردرخت غيرتهي راست بايد بزرگتر از مقدار کليد واقع در ريشه زيردرخت چپ باشد. زيردرختان چپ و راست نيز خود درختان جستجوي دودويي ميباشند.

180 7-5 درختان جستجوي دودويي 30 40 5 2 مثال

181 7-5 جستجوي يک درخت دودويي فرض کنيد خواسته باشيم دنبال عنصري با کليد key بگرديم. ابتدا از ريشه (root) شروع مي کنيم ، اگر ريشه تهي باشد ، درخت جستجو فاقد هر عنصري بوده و جستجو ناموفق خواهد بود. در غير اين صورت keyرا با با مقدار کليد ريشه مقايسه کرده : اگر key کمتر از مقدار کليد ريشه باشد ، هيچ عنصري در زيردرخت راست وجود ندارد که داراي کليدي برابر key باشد ، بنابراين زيردرخت چپ ريشه را جستجو مي کنيم. اگر key بزرگتر از مقدار کليد ريشه باشد ، زيردرخت راست را جستجو مي کنيم.

182 7-5 تحليل search اگر h ارتفاع يا عمق يک درخت جستجوي دودويي باشد ، عمل جستجو را در مدت O(h) انجام مي شود.

183 7-5 درج عنصري به داخل درخت جستجوي دودويي
براي درج عنصر جديدي به نام key ، ابتدا بايد مشخص نمود که آيا کليد با عناصر موجود متفاوت است يا خير. براي انجام اين کار بايد درخت را جستجو کرد، اگرجستجو ناموفق باشد ، عنصر را در محلي که جستجو خاتمه پيدا نموده است ، درج مي کنيم.

184 7-5 درج عنصري به داخل درخت جتجوي دودويي
مثال 30 40 5 2 35 80 30 40 5 2 جايگذاري 80 30 40 5 2 80 جايگذاري 35

185 7-5 تحليل insert_node زمان لازم براي جستجوي num در يک درخت برابر O(h) مي باشد به نحوي که h برابر با عمق يا ارتفاع درخت است. بقيه الگوريتم نياز به زمان Θ(1) دارد. بنابراين زمان کل مورد نياز insert_node برابر با Θ(h) مي باشد.

186 7-5 حذف عنصري از درخت جستجوي دودويي
براي حذف 35 از درخت زير بايد فيلد فرزند چپ والد اين گروه را برابر NULL قرار داده و گره را آزاد نمود : 30 40 5 2 35 80

187 7-5 حذف عنصري از درخت جستجوي دودويي
زماني که يک گره برگ با دو فرزند حذف مي شوند ، گره را با بزرگترين عنصر در زير درخت چپ و يا کوچکترين عنصر در زيردرخت راست آن گره جايگزين و تعويض کرد. عمل حذف در زمان O(h) انجام مي گيرد ، به نحوي که h عمق درخت مي باشد.

188 7-5 درختان جستجوي متعادل درختان جستجو با بيشترين عمق ، درختان جستجوي متعادل ناميده مي شوند. درختان جستجوي متعادلي وجود دارند که عمل جستجو ، درج و حذف را در زمان O(h) ممکن مي سازند از جمله درختان red_black ، 2-3 ، AVL

189 8-5 درختان انتخابي فرض کنيد داراي k مجموعه و رشته مرتب شده اي از عناصر هستيم که بايد در يک رشته واحد ادغام شوند. هر دنباله يا ترتيب شامل تعدادي رکورد به ترتيب غيرنزولي و فيلد مشخصي به نام key مي باشد. يک دنباله مرتب اجرا (run) ناميده مي شود. فرض کنيد که n، تعداد رکوردها در k اجرا باشد، عمل ادغام مي تواند با تکرار رکورد با کوچکترين کليد انجام شود.

190 8-5 درختان انتخابي کوچکترين کليد بايد ازبين k امکان موجود پيدا شود و مي تواند رکوردي قبل از هر k اجرا (k-runs) باشد. بهترين روش براي ادغام k اجرا (k-runs) ، نيازمند k-1 مقايسه براي تعيين و انتقال رکورد بعدي به خروجي مي باشد. به ازاي k>2 ، مي توانيم با استفاده از ايده درخت انتخابي ، تعداد مقايسه هاي لازم جهت تعيين کوچکترين عنصر را کاهش دهيم.

191 8-5 درختان انتخابي يک درخت انتخابي ، يک درخت دودويي است که هر گره آن کوچکتر از دو فرزند خود مي باشد بنابراين ، گره ريشه نشان دهنده کوچکترين گره در درخت مي باشد.

192 8-5 درختان انتخابي مثال run1 run 2 run 3 run 4 run 5 run 6 run 7 run 8
9 17 10 20 90 [1] [2] [4] [3] [5] [12] [11] [10] [9] [8] [6] [14] [13] [15] [7] مثال 15 16 20 38 20 30 15 25 15 50 11 16 100 110 18 20 run1 run 2 run 3 run 4 run 5 run 6 run 7 run 8

193 8-5 درختان انتخابي زمان تجديد ساختار درخت برابر مي باشد.
زمان تجديد ساختار درخت برابر مي باشد. زمان لازم براي ادغام تمام n رکورد برابر مي باشد. زمان کل لازم جهت ادغام k اجرا (run) برابر مي باشد.

194 9-5 جنگل ها جنگل مجموعه n ≥ 0 درخت مجزا مي باشد.
اگر ريشه درخت را حذف کنيم ، آنگاه داراي يک جنگل خواهيم بود.

195 9-5 تبديل جنگل به يک درخت دودويي
براي تبديل اين جنگل به يک درخت دودويي واحد : ابتدا نمايش دودويي هر يک از درختان جنگل را به دست مي آوريم سپس تمام درختان دودويي را از طريق فيلد همزاد گره ريشه به يکديگر متصل مي کنيم.

196 9-5 تبديل جنگل به يک درخت دودويي
A D B C E F G I H تبديل به درخت دودويي A E B F G I H C D

197 9-5 تبديل جنگل به يک درخت دودويي
اگر جنگلي از درختان باشد ، آنگاه درخت دودويي متناظر با اين جنگل يعني B: اگر n=0 باشد ، تهي خواهد بود. داراي ريشه اي برابر با ريشه مي باشد ، داراي زيردرخت چپي برابر با مي باشد ، به نحوي که زيردرختان ريشه مي باشند و در نهايت داراي زيردرخت راست مي باشد.

198 9-5 پيمايش جنگل پيمايش هاي postorder ، inorder ، preorder متناظر درخت دودويي T يک جنگل F داراي يک تناظر طبيعي با پيمايش هاي F مي باشند.

199 9-5 پيمايش جنگل پيمايش preorder مربوط به T معادل با بازيابي گره هاي F در درخت preorder مي باشد: اگر F تهي باشد ، برگرديد. ريشه درخت اول F را بازيابي کنيد. زيردرخت ، درخت اول را به صورت preorder پيمايش کنيد. ساير درختان F را به صورت preorder پيمايش کنيد.

200 9-5 پيمايش جنگل پيمايش inorder مربوط به T معادل گره هاي F در درخت inorder است که به صورت زير تعريف مي شود : اگر F تهي باشد ، برگرديد. ريشه درخت ، درخت اول را به صورت inorder پيمايش کنيد. ريشه درخت اول را بازيابي کنيد. ساير درختان را به صورت inorder پيمايش کنيد.

201 9-5 پيمايش جنگل هيچ گونه معادل طبيعي براي براي پيمايش postorder درخت دودويي متناظر يک جنگل وجود ندارد . پيمايش postorder يک جنگل F را به صورت زير بيان ي کنيم : 1) اگر F تهي باشد ، برگرديد. 2) زيردرخت ، اولين درخت F را به صورت postorder پيمايش کنيد. 3) ساير درختان باقي ماندهF را به صورت postorder پيمايش کنيد. 4) ريشه اولين درختF را بازيابي کنيد

202 10-5 نمايش مجموعه مثال ده عضو از 0 تا 9 که به سه مجموعه مجزا از هم تفکيک شده باشند ، مي توانند بدين صورت باشند : 8 6 7 4 9 1 2 5 3

203 10-5 نمايش مجموعه در هر مجموعه بر خلاف معمول که اشاره گرها به از والد به فرزندان در نظر گرفته مي شدند، در اينجا اشاره گرها از فرزندان به والد تنظيم مي شوند و يا در حقيقت گره ها با رابطه پدري اتصال يافته اند.

204 10-5 اعمال روي مجموعه ها حداقل اعمالي که بر روي مجموعه انجام مي شود ، به شرح زير است : اجتماع مجموعه مجزا (union) : اگر دو مجموعه مجزا باشند ، انگاه اجتماع آنها به صورت زير تعريف مي شود : { همه اعضا به صورت x که x يا عضو باشد يا عضو } 2) find(i)( پيداکردن i ) : مجموعه اي که i عضو آن است را پيدا کنيد

205 10-5 اعمال روي مجموعه ها مثال 8 6 7 4 9 1

206 10-5 قانون Weighting برايUnion(i ، j )
تعريف قانون Weighting برايUnion(i ، j ) : اگر تعدا گره ها در درخت i کمتر از تعداد گره ها در درخت j باشد ، j را والد i ، در غير اين صورت i را والد j قرار مي دهيم.

207 10-5 پياده سازي قانون Weighting
براي پياده سازي قانون Weighting بايد بدانيم که در هر درخت چند گره وجود دارد. اين کار را بدين ترتيب انجام مي دهيم که در ريشه هر درخت يک فيلد count قرار مي دهيم. اگر i يک گره ريشه باشد ، آنگاه در count[i] تعداد گره هاي آن درخت خواهد بود. Count به صورت يک عدد منفي در فيلد parent گذاشته مي شود. زماني که قانون Weightingرا بيان مي کنيم ، عمل اجتماع به اين صورت را union2 مي ناميم.

208 10-5 مجموعه ها اصل موضوعي : فرض کنيد T يک درخت با n گره باشد که توسط union2 ايجاد شده باشد ، در اين صورت هيچ گرهي در T ، سطحي بيشتر از نخواهد داشت. اگر در يک درخت n عضو وجو.د داشته باشد ، بيشترين زمان براي يافتن يک عضو به صورت خواهد بود. اگر ترکيبي از n-1 عمل union و m عملfind داشته باشيم ، در بدترين حالت ممکن ، زمان به صورت درمي آيد. تعريف ( قانون تخريب ) : اگر j گرهي روي مسير از i تا ريشه خود باشد ، آنگاه j را فرزند ريشه قرار دهيد.

209 11-5 شمارش درختان دودويي تعداد درختان دودويي مجزا :
تعداد درختان دودويي با n گره ، تعداد جايگشت هاي از 1 تا n با استفاده از يک پشته و بالاخره تعداد راههاي ضرب n+1 ماتريس ، باهم مساوي اند.

210 11-5 تعداد درختان دودويي مجزا
براي به دست آوردن تعداد درختان مجزا با n گره از تابع زير استفاده مي کنيم : تابع فوق توليدکننده تعداد درختان دودويي است. که برابر است با : در نتيجه داريم :

211 فصل ششم: گراف ها اهداف آشنايي با گراف ماتريس مجاورتي جستجوي گراف
شبکه ها

212 فصل ششم : گراف ها هر گراف G شامل دو مجموعه V وE است :
V(G) و E(G) : مجموعه رئوس و لبه هاي گراف G را نمايش مي دهند. براي نمايش گراف هم مي توانيم بنويسيم G=(V ، E)

213 1-6 گراف ها در يک گراف بدون جهت، زوج رئوس ، زوج مرتب نيستند ، بنابراين زوج هاي با هم يکسانند. در يک گراف جهت دار هر لبه با زوج مرتب نمايش داده مي شود. انتها و ابتداي لبه هستند. بنابراين و دو لبه متفاوت را نمايش مي دهند.

214 1-6 گراف ها براي گراف بدون جهت ، لبه ها به صورت خطوط يا منحني نمايش داده مي شوند. براي گراف هاي جهت دار لبه ها به صورت فلش هايي که از انتها به ابتدا رسم شده است ، ارايه مي گردند. مثال 2 1 F 6 4 3 1 2 2 1 3 بدون جهت جهت دار

215 1-6 محدوديت هاي گراف ها محدوديت هاي زير بر روي گراف ها اعمال مي شود :
يک گراف فاقد لبه اي از يک راس مانندi ، به خودش مي باشد. اين مطلب بدين معني است که لبه غير معتبر مي باشد. يک گراف فاقد رويداد چندگانه از يک لبه مي باشد. گراف کامل : گراف کامل گرافي است که داراي حداکثر تعداد لبه باشد.

216 1-6 گراف ها براي يک گراف بدون جهت با n راس ، حداکثر تعداد لبه ها ، تعداد متمايز و غيرمرتب زوج هاي ، i ≠ j مي باشد. ايت تعداد برابر است با : n(n-1 ) / 2 اگرگراف جهت داري با n گره وجود داشته باشد، بيشترين تعداد لبه هاي آن برابر است با : n(n-1)

217 1-6 گراف ها اگر يک لبه در گراف بدون جهت باشد ، مي گوييم رئوس و دو راس مجاور و لبه يک لبه متلاقي روي و است . يک زير گراف G، گرافي است مانند به نحوي که و باشد.

218 1-6 گراف ها طول يک مسير تعداد لبه هاي موجود در آن است.
مسير ساده ، مسيري است که همه رئوس آن احتمالا به جز اولي و آخري مجزا باشند. حلقه يا سيکل ، يک مسيرساده است که اولين و آخرين راس آن يکي باشد. 2 1 3 براي مثال 0،1،2،0 يک حلقه در است.

219 1-6 گراف ها در گراف بدون جهت مانند G ، دو راس و را متصل مي گويند، اگر مسيري در G از به وجود داشته باشد. يک گراف بدون جهت را متصل مي ناميم اگر براي هر زوج راس در V(G) ،مسيري از به در G وجود داشته باشد. يک مولفه اتصال يا به طور ساده تر يک مولفه ، در گراف بدون جهت ، بزرگترين زيرگراف متصل آن است.

220 1-6 گراف ها يک گراف جهت دار کاملا متصل ناميده مي شود ، اگر براي هر زوج از رئوس در V(G) ، مسيري جهت دار از به و همچنين از به وجود داشته باشد. يک مولفه کاملا متصل ، بزرگترين زيرگرافي است که کاملا متصل باشد. 1 2 1 2 مولفه کاملا متصل مثال

221 1-6 گراف ها درجه يک راس تعداد لبه هاي متلاقي با آن راس است .
اگر در گراف G با n راس ، درجه راس i و e تعداد لبه ها باشد ، به آساني مي توان ديد که تعداد لبه ها برابر است با :

222 1-6 نمايش گراف نمايش گراف ها به سه صورت است : ماتريس مجاورتي
ليست هاي مجاورتي ليست هاي چندگانه

223 1-6 ماتريس مجاورتي فرض کنيد G=(V ، E) يک گراف با n راس باشد ، n ≥ 1، ماتريس مجاورتي گراف G يک آرايه دوبعدي n × n به نام adj_mat مي باشد. اگر لبه (براي گراف جهت دار ) در E(G) باشد ، آنگاه adj_mat[i] [j]= 0 خواهد بود. ماتريس مجاورتي براي يک گراف بدون جهت متقارن است زيرا لبه در E(G) خواهد بود ، اگر و تنها اگر لبه نيز در E(G) باشد

224 6-1 ماتريس مجاورتي (مثال )
2 1 3 1 2 3 ماتريس مجاورتي

225 1-6 ماتريس مجاورتي براي گراف بدون جهت ، درجه هر راس مانند i مجموع عناصر سطري آن است : براي يک گراف جهت دار ، مجموع سطري ، درجه خارجه و مجموع ستوني ، درجه وارده خواهد بود.

226 6-1 ليست هاي مجاورتي با اين نمايش ، n سطر ماتريس مجاورتي در n ليست پيوندي قرار مي گيرد. براي هرراس از گراف G ، يک ليست وجود دارد. هر گره حداقل دو فيلد دارد : راس و اتصال در هر ليست مشخصي مانند i ، گره هاي ليست حاوي رئوس مجاور از راس i مي باشند. در يک گراف بدون جهت با n راس و e لبه ، n گره head و 2e گره ليست دارد. هر گره ليست دو فيلد لازم دارد.

227 6-1 ليست هاي مجاورتي(مثال)
head nodes vertex link 1 2 3 . 1 2 3 NULL 2 1 3

228 6-1 ليست هاي مجاورتي درجه هر راس در يک گراف بدون جهت را مي توان به سادگي با شمارش تعداد گره هاي آن در ليست مجاورتي تعيين کرد. اگر تعداد رئوس گراف G برابر با n باشد ، تعداد کل لبه ها، در زمان O( n + e ) تعيين مي شود.

229 6-1 ساختار گره براي ليست هاي مجاورتي
نمايش دوم : هر گره داراي چهار فيلد بوده و نشان دهنده يک لبه است. row link for tail column link for head head tail

230 1-6 ليست هاي مجاورتي چندگانه
در نمايش ليست مجاورتي ، هر لبه در يک گراف بدون جهت مانند با دو وارده نمايش داده مي شود : در ليست براي

231 1-6 لبه هاي وزني در ماتريس مجاورتي ، کميت 1 که نشان دهنده وجود يک لبه است را با وزن يک لبه تعويض مي کنيم. در ليست هاي مجاورتي و ليست هاي مجاورتي چندگانه ، فيلد weight به ساختار گره اضافه مي شود. path2 path1 vertex2 vertex1 marked ساختار يک گره براي ليست هاي مجاورتي چندگانه گرافي که لبه هايش داراي وزن باشد ، شبکه ناميده مي شود.

232 2-6 اعمال ابتدايي گراف با توجه به گراف بدون جهت G(V ، E) و راس v از V(G) مي خواهيم رئوسي از G را که از v قابل دسترسي هستند، به دست آوريم( يعني همه رئوس متصل به v) . براي اين کار دو روش وجود دارد : جستجوي عمقي : روش عمقي تا حدودي شبيه پيمايش preorder يک درخت است. جستجوي رديفي : اين روش تا حدودي پيمايش ترتيب سطحي را مجسم مي کند. در پيمايش هاي عمقي و رديفي ، فرض مي کنيم که براي نمايش گراف ها از ليست مجاورتي پيوندي استفاده شده است.

233 2-6 جستجوي عمقي در آغاز راس v را ملاقات مي کنيم. بعد راسي مانند w را که قبلا ملاقات نشده و مجاور به v است را انتخاب کرده و روش جستجوي عمقي را با w دنبال مي کنيم. موقعيت جاري راس v در ليست مجاورتي با قرار دادن آن در يک پشته صورت مي گيرد. در نهايت ، جستجو به راسي مانند u خواهد رسيد که فاقد هر گونه راس غيرملاقات شده در ليست مجاورتي باشد. در اين مرحله راسي از پشته انتخاب و و حذف شده و فرآيند فوق به همين صورت ادامه پيدا مي کند. بر اساس اين روش ، رئوس ملاقات شده، خارج شده و رئوس ملاقات نشده ، داخل پشته قرار مي گيرند. جستجو زماني پايان مي پذيرد که پشته تهي باشد.

234 2-6 جستجوي عمقي جستجوي عمقي شبيه پيمايش preorder يک درخت مي باشد . زيرا Void dfs (int V) { /* depth first search of a graph beginning with vertex V . */ node_pointer w ; visited[V] = TRUE ; print f ( “ %5d “ ، V ) ; for (w = graph[V] ; w ; w = w-> link ) if ( ! Visited [w->vertex] ) dfs (w-> vertex ) ; }

235 2-6 جستجوي عمقي(مثال) 1 2 3 4 5 6 7 گراف G نمايش ليست هاي مجاورتي . 1
1 2 3 4 5 6 7 . 1 2 NULL 3 5 7 4 6 نمايش ليست هاي مجاورتي

236 2-6 جستجوي عمقي(مثال) توضيح شکل قبل
اگر روش جستجوي عمقي را از راس آغاز کنيم ، رئوس گراف G به ترتيب ملاقات مي شوند.

237 2-6 تحليل dfs اگر G توسط ماتريس مجاورتي نمايش داده شود ، زمان لازم براي تعيين همه رئوس مجاور به v ، O(n) است. از آنجا که حداکثر n راس مشاهده مي شود ، کل زمان خواهد شد.

238 2-6 جستجوي رديفي پيمايش را با راس v شروع نموده ، پس از ملاقات راس مزبور ، آنرا علامت گذاري مي کنيم. اول هر يک از رئوس مجاور به راس v را در ليست مجاورتي ملاقات مي کنيم. زماني که همه رئوس مجاور با راس v را ملاقات کرديم ، تمام رئوس ملاقات نشده که مجاور با اولين راس مجاور با v در ليست مجاورتي است را ملاقات مي کنيم. براي انجام اين کار ماداميکه هر راس ملاقات مي شود ، آنرا در يک صف قرار مي دهيم. هنگامي که ليست مجاورتي تمام شد ، راسي را از صف حذف و با تست هر يک از رئوس در ليست مجاورتي اين فرآيند را ادامه مي دهيم. رئوس ملاقات نشده ، ملاقات و سپس در صف قرار مي گيرند. رئوس ملاقات شده ناديده گرفته مي شوند. جستجو هنگامي که صف تهي گردد ، خاتمه مي يابد.

239 2-6 جستجوي رديفي تابع bfs حاوي دستورات لازم جهت پياده سازي جستجوي رديفي است.

240 2-6 درخت هاي پوشا چنانچه گراف G متصل باشد ، پيمايش هاي جستجوي عمقي يا جستجوي رديفي ، تمام رئوس گراف G را ملاقات مي کنند. در اين حالت با اعمال هر يک از پيمايش ها لبه هاي گراف G به دو قسمت تقسيم مي شوند : T ( براي لبه هاي درخت ) : مجموعه لبه هاي به کار رفته يا پيموده شده در جستجو مي باشد. N (براي لبه هاي غير درخت ) : مجموعه لبه هاي باقي مانده مي باشد.

241 2-6 درخت هاي پوشا لبه هاي T ، يک درخت که شامل تمام رئوس گراف G مي باشد را تشکيل مي دهند . تعريف درخت پوشا : درختي که تعدادي از لبه ها و تمام رئوس G را در بر دارد ، درخت پوشا ناميده مي شود : گراف سه درخت پوشاي آن

242 2-6 درخت هاي پوشا درخت پوشايي که از فراخواني dfs به دست مي آيد را درخت پوشاي عمقي مي نامند. چنانچه از روش bfs استفاده شود ، درخت پوشاي حاصل را درخت پوشاي رديفي مي نامند. درخت پوشاي dfs درخت پوشاي bfs

243 2-6 درخت هاي پوشا مقصود از زير گراف حداقل ، يعني زيرگرافي که تعداد لبه هايش کمترين باشد. هر گراف متصل با n راس ، بايستي حداقل n-1 لبه داشته باشد و همه گراف ها متصل با n-1 لبه ، درخت هستند. درخت پوشا داراي n-1 لبه مي باشد. ايجاد زيرگراف هاي حداقل ، کاربردهاي متعددي در طراحي شبکه هاي ارتباطي دارد. مثال : اگر رئوس گراف G نماينده شهرها و لبه ها معرف جاده هاي ارتباطي بين شهرها بلشد ، آنگاه حداقل تعداد خطوط مورد نياز براي اتصال n شهر به يکديگر n-1 خواهد بود.

244 2-6 اجزاي دو اتصالي و نقاط اتصال
نقطه اتصال : يک راس مانند v از گراف G مي باشد به نحوي که حذف راس v همراه با تمام لبه هاي متلاقي با v ، گرافي به نام ايجادمي کند که حداقل داراي دو جز متصل است. گراف دو اتصالي يک گراف متصل است اگر فاقد نقاط اتصالي باشد . 9 5 1 3 2 6 4 8 7 گراف دو اتصالي گراف متصل

245 2-6 اجزاي دو اتصالي و نقاط اتصال
اجزاي دو اتصالي يک گراف بدون جهت متصل مانند G يک زير گراف دو اتصالي حداکثري به نام H مي باشد. منظور از اين حداکثر اين است که G فاقد زيردرختاني است که هم دو اتصالي و هم داراي خاصيت H باشند. با استفاده از درخت پوشاي عمقي گراف G ، مي توان اجزاي دو اتصالي يک گراف بدون جهت متصل را به دست آورد. يک لبه غيردرختي مانند يک لبه غيربرگشتي است (back edge ) ، اگر و تنها اگر u جد v و يا v جد u باشد.

246 2-6 اجزاي دو اتصالي و نقاط اتصال
ريشه يک درخت پوشاي عمقي يک نقطه اتصال است ، اگر و تنها اگر داراي حداقل دو فرزند باشد. هر راس مانند U يک نقطه اتصال است ، اگر و تنها اگر داراي يک فرزند مانند W باشد به نحوي که قادر باشيم با استفاده از يک مسير که شامل تنها W ، نسل ها و يک لبه برگشتي ، به جد u برسيم.

247 2-6 اجزاي دو اتصالي و نقاط اتصال
براي هر راس در G ، low(u) پايين ترين عدد عمقي است که مي توانيم از U با استفاده از يک مسير نسل ها به دنبال حداکثر يک لبه برگشتي ، به آن برسيم. Low (u) = min { dfn (u) ، min {low(w) │ w is a child of u } ، min { dfn (w) │ ( u ، w ) is a back edge } } که u يک نقطه اتصال است ، اگر و تنها اگر u ريشه يک درخت پوشا بوده و داراي دو فرزند يا بيشتر باشد و يا u ريشه نباشد و داراي يک فرزند مانند w است به نحوي که low (w) ≥ = dfn (u) است.

248 2-6 اجزاي دو اتصالي و نقاط اتصال
4 2 3 1 8 5 6 7 9 9 8 7 6 5 4 3 2 1 Vertex dfn low مقدير dfn و low براي درخت پوشاي با root = 3

249 3-6 درختان پوشاي با حداقل هزينه
هزينه يک درخت پوشاي يک گراف جهت دار داراي وزن ، مجموع هزينه هاي( وزن هاي) لبه ها در درخت پوشا مي باشد. درخت پوشاي حداقل هزينه ، درخت پوشايي است که داراي کمترين هزينه باشد. براي به دست آوردن درخت پوشاي حداقل هزينه يک گراف جهت دارمتصل مي توان از سه الگوريتم متفاوت استفاده نمود : الگوريتم راشال ، الگوريتم پريم ، الگوريتم سولين هر سه روش از يک طراحي الگوريتمي به نام خط مشي greedy استفاده مي کنند.

250 3-6 درختان پوشاي با حداقل هزينه
براي درخت هاي پوشا از ملاک کمترين هزينه استفاده مي شود. روش ما بايد داراي شرايط زير باشد : بايد فقط از لبه هاي داخل گراف استفاده کنيم. بايد دقيقا از n-1 لبه استفاده کنيم. نبايد از لبه هايي که ايجاد يک حلقه مي کنند ، استفاده کنيم.

251 3-6 الگوريتم راشال در اين روش ، درخت پوشاي با کمترين هزينه T ، لبه به لبه ساخته مي شود. لبه هاي مورد استفاده در T ، به ترتيب صعودي وزن ها مي باشد. يک لبه در T خواهد بود، اگر با لبه هاي قبل که در T بوده اند ، تشکيل يک حلقه ندهد چون G متصل است و داراي n > 0 راس است ، دقيقا n – 1 لبه براي T انتخاب مي شود.

252 3-6 الگوريتم راشال (مثال)
1 5 2 6 4 3 10 25 24 22 18 12 16 28 14 1 5 2 6 4 3 1 5 2 6 4 3 10 1 5 2 6 4 3 10 12 25 1 5 2 6 4 3 10 12 14 16 22 1 5 2 6 4 3 10 12 14 16 22 1 5 2 6 4 3 10 12 14 16 1 5 2 6 4 3 10 12 14

253 3-6 الگوريتم راشال قضيه فرض کنيد G يک گراف متصل بدون جهت باشد ، الگوريتم راشال يک درخت پوشاي حداقل را ايجاد مي کند.

254 3-6 الگوريتم پريم الگوريتم پريم مانند الگوريتم راشال ، در هر زمان يک لبه از درخت پوشاي حداقل هزينه را مي سازد. هر چند در هر مرحله الگوريتم ، مجموعه لبه ها انتخاب شده يک درخت را تشکيل مي دهند . در مقابل ، مجموعه لبه هاي انتخاب شده در الگوريتم راشال در هر مرحله يک جنگل را تشکيل مي دهند. الگوريتم پريم با يک درخت مانند T ، که تنها شامل يک راس است ، شروع مي کند. اين مي تواند هر يک از رئوس در گراف اصلي باشد. سپس يک لبه با کمترين هزينه مانند به T اضافه مي شود به نحوي که نيز خود يک درخت مي باشد. اين عمل را تا زماني که T شامل n – 1 لبه باشد ، ادامه مي دهيم.

255 3-6 الگوريتم پريم (مثال ) 1 5 2 6 4 3 10 25 24 22 18 12 16 28 14 1 5 2 6 4 3 10 25 1 5 2 6 4 3 10 25 1 5 2 6 4 3 10 22 25 1 5 2 6 4 3 10 12 14 16 22 25 1 5 2 6 4 3 10 12 16 22 25 1 5 2 6 4 3 10 12 22

256 3-6 الگوريتم سولين بر خلاف الگوريتم پريم و راشال ، الگوريتم سولين چندين لبه را براي اضافه نمودن در هر مرحله انتخاب مي کند. در ابتدا يک مرحله ، لبه هاي انتخاب شده ، همراه با تمام n راس گراف ، تشکيل يک درخت پوشا را مي دهند. در خلال يک مرحله يک لبه براي هر درخت در جنگل انتخاب مي کنيم. اين لبه داراي حداقل هزينه بوده يعني دقيقا داراي يک راس در درخت مي باشد. از آنجا که دو درخت در جنگل مي توانند يک لبه يکسان انتخاب کنند ، لذا مي توانيم کپي تکراري از لبه ها را حذف کنيم. در ابتداي مرحله اول ، مجموعه لبه هاي انتخاب شده خالي مي باشد. اين الگوريتم هنگامي به پايان مي رسد که فقط يک درخت در انتهاي يک مرحله باقي و يا هيچ لبه اي براي انتخاب باقي نمانده باشد.

257 3-6 الگوريتم سولين (مثال )
1 5 2 6 4 3 10 12 14 22 1 5 2 6 4 3 10 25 24 22 18 12 16 28 14 25 1 5 2 6 4 3 10 12 14 16 22

258 4-6 يک مبدا و چند مقصد در اين مساله گراف جهت دار G = (V ، E ) را در نظر مي گيريم. تابع وزني w(e) >0 را براي لبه هاي G و راس مبدا فرض مي کنيم. مساله ، تعيين کوتاهترين مسير از به بقيه رئوس در G است. فرض مي کنيم تمام وزن ها مثبت باشند. 45 20 10 15 3 35 30 50 path length 1) 2) 3) 4) 10 25 45 يک گراف و کوتاهترين مسير از

259 4-6 کوتاهترين مسير بين هر جفت از رئوس
مساله کوتاهترين مسير بين هر زوج از رئوس به مفهوم يافتن کوتاهترين مسير بين همه رئوس مي باشد ( به طوري که i ≠ j ) از آنجا که G داراي n راس و shortestpath داراي زمان مي باشد، لذا کل زمان صرف شده خواهد بود. گراف G توسط ماتريس مجاورتي هزينه خود با cost[i][j] = 0 ارايه مي شود (i = j) و در صورتي که لبه ( i ≠ j ) < i ، j > در G نباشد، cost[i][j] حاوي عدد بزرگي خواهد بود که اين عدد بايد همان محدوديت هاي مطرح شده در خصوص مساله يک مبدا ( single source ) را دارا باشد.

260 4-6 کوتاهترين مسير بين هر جفت از رئوس
را هزينه کوتاهترين مسير از i به j تعريف مي کنيم که اين مسير هيچ راس مياني که انديس کوچکتر يا مساوي از (index ≤ k) k داشته باشيم ، عبور نمي کند. هزينه کوتاهترين مسير از i به j در G است. نکته اصلي در همه الگوريتم هايي که روي زوج ها عمل مي کنند ، اين مي باشد که همه آنها با شروع کرده و ماتريس هاي متوالي را ايجاد مي کند.

261 4-6 کوتاهترين مسير بين هر جفت از رئوس
اگر قبلا را توليد کرده باشيم ، مي توانيم را با عمل روي هر زوج از رئوس i و j با توجه به يکي از دو قاعده زير به دست آوريم : کوتاهترين مسير از i به j از هيچ راسي با انديس بزرگتر از k عبور نمي کند و حتي از راسي با انديس k نيز نمي گذرد و بنابراين هزينه آن است. چنين کوتاهترين مسيري از راس k مي گذرد بنابراين چنين مسيري شامل مسيري از i به k و به دنبال آن مسيري از k به i مي باشد. هيچ کدام از اين مسيرها با انديس بزرگتر از k-1 عبور نخواهد کرد ، بنابراين هزينه آن ها و مي باشد.

262 4-6 کوتاهترين مسير بين هر جفت از رئوس
: فرمول 1 : فرمول 2 تابع allcosts را محاسبه مي کند. زمان کل allcosts برابر است.

263 4-6 گراف جهت دارG و ماتريس هزينه آن ( مثال)
2 11 3 1 2 ماتريس مجاورتي هزينه ها براي گراف G گراف جهت دار G

264 4-6 ماتريس هاي توليد شده توسط allcosts (مثال)
1 2 1 2 1 2 (1) (2) 1 2 1 2 (3) (4)

265 4-6 بسته بودن تعدي در يک گراف جهت دار با لبه هاي بدون وزن مانند G ، آيا براي هر دو راس مانند i وj ، مسيري از i به j وجود دارد يا خير؟ دو حالت مي تواند مورد توجه قرار بگيرد : وقتي که همه مسيرها طول مثبت داشته باشند که بسته بودن تعدي يک گراف ناميده مي شود. زماني که طول مسيرها غيرمنفي باشد که بسته بودن تعدي انعکاسي يک گراف ناميده مي شود.

266 4-6 ماتريس بسته بودن تعدي و ماتريس بسته بودن تعدي انعکاسي
تعريف : ماتريس بسته بودن تعدي ، ، يک گراف جهت دار مانند G ، ماتريسي است که اگر مسيري از i به j با طول بزرگتر از صفر وجود داشته باشد ، بوده و در غير اين صورت خواهد بود. تعريف : ماتريس بسته بودن تعدي انعکاسي ، ، يک گراف جهت دار مانند G ، ماتريسي است که اگر مسيري بزرگتر يا مساوي با صفر از i به j وجود داشته باشد، بوده و در غير اين صورت خواهد بود. تنها تفاوت و در عناصر روي قطر اصلي است. بنابراين مي باشد

267 5-6 شبکه AOV تعريف : شبکه AOV (activity on vertex) گراف جهت داري مانندG است که رئوس آن نمايانگر فعاليت ها يا عملکردها است و لبه هاي آن نمايانگر ارتباطات بين عملکردها مي باشد، اين گراف ، شبکه فعاليت هاي روي رئوس يا شبکه AOV ناميده مي شود.

268 5-6 شبکه AOV تعريف : راس i در يک شبکه AOV مربوط به گراف G ، يک راس تقدمي براي راس j خواهد بود، اگر و تنها اگر مسير جهت داري از راس i به j وجود داشته باشد. اگر و تنها اگر <i ، j > لبه اي در G باشد ، i يک راس تقدمي بلافصل براي j است. اگر i يک راس تقدمي براي j باشد ، آنگاه j راس تاخيري براي i مي باشد. اگر i يک راس تقدمي بلافصل براي j باشد ، آنگاه j راس تاخيري بلافصل براي i مي باشد.

269 5-6 شبکه AOV (مثال) c8 c7 c3 c11 c15 c5 c4 c6 c14 c1 c2 c9 c10 c13 c12

270 5-6 شبکه AOV تعريف : يک رابطه . تعدي است اگر وتنها اگر براي تمام سه گانه هاي i . j ‚i ، j ، kوj . k ، i . Kرا نتيجه مي دهد(i.j and j.k => i.k) يک رايطه . روي مجموعه S غير انعکاسي است ، اگربراي تمامي مقادير i در S ، i . i نادرست (flash) باشد. رابطه اي که هم تعدي و هم غير انعکاسي باشد ، يک رابطه ترتيبي ناميده مي شود. اگر رابطه تقدمي غيرانعکاسي نباشد ، آنگاه فعاليتي وجود دارد که راس تقدمي آن خودش است.

271 5-6 شبکه AOV گراف جهت داري که هيچ حلقه اي نداشته باشد ، گراف acyclic جهت دار يا dag ناميده مي شود. تعريف : ترتيب موضعي يک ترتيب خطي از رئوس گراف است به نحوي که به ازاي هر دو راس i و j ، اگر i يک راس تقدمي براي j در شبکه باشد ، آنگاه i در اين ترتيب خطي بيش از j قرار مي گيرد.

272 5-6 فعاليت بر روي لبه (AOV) شبکه
يک شبکه فعاليت که ارتباط نزديکي با شبکه AOV داشته باشد ، فعاليت روي لبه يا شبکه AOE ناميده مي شود. اعمالي که روي پروژه صورت گيرد با لبه هاي جهت دار نمايش داده مي شوند. رئوس شبکه نمايانگر وقايع است. يک واقعه فقط زماني اتفاق مي افتد که همه فعاليت هاي وارده به آن قبلا کامل شده باشد.

273 5-6 فعاليت بر روي لبه (AOV) شبکه
شبکه هاي فعاليت از نوع AOE در ارزيابي اجرايي چندين نوع از پروژه ها به طور موثري مورد استفاده قرار مي گيرند. اين ارزيابي شامل تعيين چندين نکته در مورد پروژه ها به شرح زير است : کمترين زمان ممکن براي تکميل پروژه تعيين اينکه کدام فعاليتها بايستي زودتر انجام شوند تا زمان تکميل پروژه کاهش يابد.

274 5-6 فعاليت بر روي لبه (AOV) شبکه
چندين تکنيک و روش بسيار مهم براي ارزيابي مدل هاي شبکه پروژه توسعه يافته اند از جمله : PERT ( ارزيابي اجرايي و تکنيک بازبيني) CPM ( روش مسير بحراني ) RAMPS ( تخصيص منبع و زمان بندي پروژه چندگانه )

275 5-6 فعاليت بر روي لبه (AOV) شبکه
از آنجا که فعاليتهاي يک شبکه AOE مي توانند به طور موازي انجام شوند ، کمترين زمان لازم براي کامل شدن پروژه ، اندازه طولاني ترين مسير از راس اغازي به راس پاياني است. مسيري با طولاني ترين طول ، يک مسير بحراني است.

276 5-6 فعاليت بر روي لبه (AOV) شبکه
زودترين زماني که واقعه مي تواند اتفاق بيفتد ، طولاني ترين مسير از راس آغازي به راس است. زودترين زماني که يک واقعه مي تواند اتفاق بيفتد ، زودترين زمان شروع همه وقايع موجود که از اين راس خارج شده اند را تعيين مي کند. اين زمان را به صورت early(i) براي فعاليت نشان مي دهيم.

277 5-6 فعاليت بر روي لبه (AOV) شبکه
براي هر فعاليت مانند مي توان ديرترين زمان را نيز تعريف کرد. که در واقع ديرترين زماني است که يک فعاليت مي تواند انجام شود به شرط اينکه زمان پروژه را افزايش ندهد. همه فعاليتهايي که به صورت early(i) = late(i) هستند ، فعاليت هاي بحراني ناميده مي شوند. تفاضل early(i) و late(i) ، اندازه يا ميزان بحراني بودن يک فعاليت را نشان مي دهند.

278 5-6 محاسبه زودترين زمان به منظور به دست آوردن زودترين و ديرترين زمان براي تمام فعاليتهاي يک شبکه ، مناسب است که براي تمام وقايع در شبکه ، ابتدا زودترين زمان رويداد واقعه يعني earliest[j] و سپس ديرترين زمان رويداد واقعه يا lastest[j] محاسبه نمود. سپس اگر فعاليت به وسيله لبه < k ، l > ارايه شود ، مي توانيم early(i) وlate(i) را از فرمول زير محاسبه کنيم : late(i) = latest [l] – duration of activity زمان earliest[j] و lastest[j] در دو مرحله محاسبه مي گردد : مرحله پيشرو و مرحله پسرو

279 فصل هفتم: مرتب سازي اهداف جستجو جستجوي دودويي مرتب سازي درجي
مرتب سازي سريع مرتب سازي ادغام مرتب سازي ليست .....

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

281 1-7 اصطلاحات زماني که يک ليست از رکوردها را جستجو مي کنيم ، هدف پيدا نمودن رکوردهايي است که داراي فيلدي با مشخصات مورد نياز باشند. اين فيلد را اصطلاحا کليد مي نامند. کارايي روش و خط مشي جستجو بستگي به آرايش و نحوه قرار گرفتن رکوردها در ليست دارد.

282 1-7 جستجوي ترتيبي فرض کنيد که ليست و يک کليد جستجو به نام Searchnum داشته باشيم . هدف بازيابي رکوردي است که کليد آن منطبق بر searchnum باشد. اگر اين ليست داراي n رکورد باشد ، با list[i].key به مقدار کليد رکورد i دسترسي پيدا مي کنيم، ليست را با جستجوي مقادير کليدهايlist[n-1].key ، … ، list[0].key مورد بررسي قرار مي دهيم تا به رکورد مورد نظر برسيم يا تمام ليست را جستجو کنيم.

283 1-7 تحليل تابع seqsearch تابع seqsearch نحوه جستجوي ترتيبي را نشان مي دهد. تحليل تابع seqsearch : قبل از شروع جستجو ، seqsearch را در موقعيت list[n].key قرار مي دهيم. اين موقعيت در واقع انتهاي ليست را نشان مي دهد. با جلوگيري از تست پايان ليست ، يعني شرايطي که i > n -1 باشد، مي توانيم براحتي ساختار حلقه را ساده کنيم. اگر عمل جستجو موفقيت آميز نباشد، i = n ، مقدار -1 را برمي گردانيم . بنابراين در يک جستجوي ناموفق نياز به n + 1 عمل مقايسه کليد داريم که زمان آنO(n) خواهد بود.

284 1-7 تحليل تابع seqsearch ميانگين تعداد عمل مقايسه در يک جستجوي موفقيت آميز برابر است با :

285 1-7 جستجوي دودويي در جستجوي دودويي بايستي ليست بر اساس فيلد کليد مرتب شود ، يعني : .list[0].key ≤ list[1].key ≤ … ≤ list[n-1].key

286 1-7 جستجوي دودويي اين جستجو با مقايسه searchnum و list[middle].key ، به ازاي middle=(n-1)/2 شروع مي شود. هنگام مقايسه سه حالت ممکن است روي دهد : searchnum< list[middle].key : در اين حالت رکوردهايي بين list[middle] و list[n-1] کنار گذاشته شده و جستجو با رکوردهاي List[0] تا List[middle-1] دنبال مي شود. Searchnum= list[middle].key : در اين حالت جستجو با موفقيت به پايان مي رسد. searchnum> list[middle].key : در اين حالت ، رکوردهاي بين List[0] و list[middle] کنار گذاشته شده و جستجو با رکوردهاي list[middle+1] تا list[n-1] دنبال مي شود.

287 1-7 درخت تصميم گيري براي جستجوي دودويي
46 58 17 4 48 90 26 15 30 56 95 82 [5] [2] [0] [8] [3] [4] [1] [6] [9] [7] [11] [10]

288 1-7 وارسي ليست(list Verification)
نوعا مقايسه ليستها جهت تعيين تست يکي بودن يا تعيين اختلاف آنها نوعي بررسي ليست به حساب مي آيد. مسئله وارسي ليست يک نمونه از جستجوي مکرر يک ليست است که هر کليد آن به عنوان کليد جستجو در ليست ديگري به کار مي رود.

289 1-7 وارسي ليست(list Verification)
تابع verify1 : دو ليست را در نظر مي گيرد که به صورت تصادفي مرتب شده اند . به سادگي مي توان ثابت نمود که زمان مجانبي اين تابع در بدترين حالت برابر با O(mn) مي باشد. تابع verify2 : از همان ورودي تابع verify1 استفاده مي کند با اين تفاوت که ليستها قبل از وارسي ، مرتب مي شوند. در بدترين حالت ، زمان لازم O(tsort (n) + tsort (m) + m+n ) خواهد بود . tsort (n) : زمان لازم جهت مرتب کردن n رکورد از ليست اول (list1) tsort (m) : زمان لازم براي مرتب کردن m رکورد از ليست دوم (list2) مي باشد.

290 2-7 مرتب سازي دو نوع از کاربردهاي مهم مرتب سازي عبارتند از :
کمک در امر جستجو تطابق عناصر و وارده ها در يک ليست

291 3-7 مرتب سازي درجيInsertion Sort

292 3-7 تحليل تابع insertion sort
زمان محاسباتي جهت درج يک رک.رد به داخل ليست مرتب شده ، O(i) خواهد بود. زمان کل در بدترين حالت برابر است با :

293 3-7 مرتب سازي درجي(مثال) رشته (1و2و3و4و5 ) را با n = 5 در نظر گرفته ، بعد از عمل درج ، داريم : i [0] [1] [2] [3] [4] زمان محاسباتي مرتب سازي درجي O(( k + 1 ) n ) مي باشد.

294 3-7 انواع مرتب سازي درجي مرتب سازي درجي دودويي :
براي انجام اين عمل بايستي به جاي جستجوي ترتيبي از جستجوي دودويي استفاده نماييم. در اين حالت ، تعداد انتقال رکورد بدون تغيير باقي خواهد ماند. مرتب سازي درجي ليست : عناصر يک ليست را مي توان به جاي قرار دادن در آرايه در يک ليست پيوندي پويا قرار داد. در اين حالت ، تعداد انتقال رکورد صفر مي شود زيرا فقط فيلد اشاره گر تغيير مي کند.

295 4-7 مرتب سازي سريع تفاوت مرتب سازي سريع با درجي در اين است که در اين نوع مرتب سازي کليد مفصل در سمت راست با توجه به کل فايل قرار مي گيرد. بنابراين اگر کليد در محل s(i) قرار بگيرد ، پس به ازاي بوده و به ازاي ، مي باشد. از اين رو بعد از جايگذاري ، فايل اصلي به دو زير فايل که شامل رکوردهاي و مي باشند ، تقسيم مي شوند. از آنجايي که رشته مرتب شده از تمام رکوردها در زير فايل اول ممکن است در سمت چپ s(i) و تمام رکوردها در زير فايل دوم در سمت راست s(i) قرار گيرند ، لذا اين دو فايل مي توانند به طور مستقل مرتب گردند.

296 4-7 مرتب سازي سريع ميانگين زمان محاسبه براي مرتب سازي سريع مي باشد.
ميانگين زمان محاسبه براي مرتب سازي سريع مي باشد. قضيه فرض کنيد زمان لازم براي مرتب سازي يک فايل با n رکورد باشد. بنابراين به بزاي مقدار ثابت k داريم :

297 4-7 مرتب سازي سريع مرتب سازي سريع جهت پياده سازي عمل بازگشت پذيري به فضاي پشته نياز دارد. حداکثر عمق بازگشت پذيري log n خواهد بود و به فضاي پشته O(log n) نياز خواهد بود.

298 5-7 زمان مرتب سازي بهينه بهترين زمان ممکن براي مرتب سازي مي باشد
بهترين زمان ممکن براي مرتب سازي مي باشد حداقل عمق يک درخت تصميم گيري براي مرتب سازي n عنصر مجزا و قابل تفکيک برابر با مي باشد. هر الگوريتمي که عمل مرتب سازي را تنها با مقايسه انجام مي دهد ، در بدترين حالت بايستي زماني برابر داشته باشد.

299 5-7 درخت تصميم گيري(مثال)
stop I No ІІ V VI ІІІ Yes [0،1،2] [1،0،2] [0،2،1] [2،0،1] [1،2،0] [2،1،0]

300 6-7 مرتب سازي ادغام الگوريتم O(1) :
مراحل در O(1) فضاي ادغام هنگامي که تعداد رکوردها يعني n مجذور کامل بوده و تعداد رکوردهاي هر فايل مورد ادغام نيز مضربي از باشد ، در نظر گرفته مي شود.

301 6-7مراحل الگوريتم O(1) مرحله 1 : رکورد با بزرگترين کليدها را مشخص کنيد. اين امر با رديابي دو فايل مورد ادغام از سمت راست به چپ صورت مي گيرد. مرحله 2 : رکوردهاي فايل دوم که از مرحله اول شناسايي شده اند را با آن دسته از رکوردهايي که در سمت چپ رکوردهايي که از فايل اول شناسايي شدند ، تعويض کنيد. اين امر موجب مي شود که رکورد با بيشترين کليد ، تشکيل يک بلاک مجاور را بدهد. مرحله 3 : بلاک با بيشترين رکورد را با بلاک هاي منتهي اليه سمت چپ تعويض کنيد( مگر اينکه آن بلاک قبلا بلاک منتهي اليه سمت چپ باشد ) . بلاک منتهي اليه سمت راست را مرتب کنيد.

302 6-7مراحل الگوريتم O(1) (ادامه)
مرحله 4 : تمام بلاک ها به جز بلاک با بزرگترين رکوردها را به ترتيب غير نزولي آخرين کليد در بلاک مرتب کنيد. مرحله 5 : هر تعداد غير مرحله ادغامي که براي ادغام بلاک ( غير از بلاک هايي با بزرگترين کليد ) نياز باشد را اجرا کنيد. مرحله 6 : بلاک با بزرگترين کليد را مرتب کنيد.

303 6-7 مرتب سازي ادغام تکراري( غير بازگشتي )
در نسخه تکراري فرض خواهد شد که رشته ورودي شامل n ليست مرتب شده به طول يک است. ليست ها را دو به دو ( جفتي ) ادغام مي کنيم تا تعداد n/2 ليست با اندازه 2به دست آوريم. سپس n/2 ليست حاصل را مجددا دو به دو ادغام مي کنيم و اين عمل را ادامه مي دهيم تا يک ليست باقي بماند.

304 6-7 مرتب سازي ادغام بازگشتي
براي نسخه بازگشتي ، ساختار رکورد خود را طوري تغيير مي دهيم تا يک فيلد اتصال (Link) را نيز دربرگيرد. الگوريتم ادغام در بدترين حالت و حالت ميانگين به زمان محاسباتي برابر با O(n log n) نياز دارد. اين الگوريتم همچنين متناسب با تعداد رکوردهايي که در فايل بايد مرتب مي شدند ، نيازمند فضاي اضافي است.

305 7-7 مرتب سازي heap روش مرتب سازي heap نيازمند تنها يک مقدار حافظه اضافي است و در همين حال ، بدترين حالت و زمان متوسط آن برابر با O(n log n) خواهد بود. با وجود اينکه مرتب سازي heap کمي کندتر از مرتب سازي ادغام با استفاده از O(n) فضاي اضافي است ولي از مرتب سازي ادغام با استفاده از O(1) فضاي اضافي سريعتر مي باشد.

306 کل زمان محاسباتي O(n log n) خواهد شد.
7-7 مرتب سازي heap براي مرتب سازي يک ليست ، n-1 گذر بر روي ليست اعمال مي شود. در هر گذر ، اولين رکورد در heap با آخرين رکورد تعويض مي گردد . از آنجا که اولين رکورد هميشه شامل بزرگترين کليد است، اين رکورد با بزرگترين کليد را در محل n ام قرار مي دهيم. در گذر دوم رکورد با دومين کليد بزرگ را در موقعيت n-1 قرار مي دهيم و در نهايت در i امين گذر ، رکورد با i امين کليد بزرگ را در موقعيت n - i + 1 قرار مي دهيم. کل زمان محاسباتي O(n log n) خواهد شد.

307 8-7 مرتب سازي مبنا در اينجا توجه خود را روي مرتب سازي رکوردهايي معطوف مي کنيم که داراي چندين کليد هستند. اين کليدها داراي برچسب مي باشد. به نحوي که نشان دهنده با اهميت ترين کليد و مشخص کننده کم اهميت ترين کليد است. MSD ( با ارزش ترين رقم ) LSD ( کم ارزش ترين رقم ) روش هاي مختلف مرتب سازي :

308 O(MAX_DIGIT (RADIX_SIZE + n )
8-7 مرتب سازي مبنا در مرتب سازي مبنا با استفاده از مبنا r کليد مرتب سازي را تجزيه مي کنيم. زمان محاسباتي کل برابراست با : O(MAX_DIGIT (RADIX_SIZE + n ) انتخاب مبنا در زمان مرتب سازي مبنا موثر است .

309 9-7 مرتب سازي ليست و جدول اين مرتب سازي ، ليست را به طور فيزيکي مرتب نکرده بلکه فيلدهاي اتصال را براي نشان دادن ترتيب عناصر اصلاح مي کند.

310 10-7 خلاصه مرتب سازي داخلي مرتب سازي درجي زماني که ليست به صورت جزيي مرتب شده باشد ، خوب کار مي کند. مرتب سازي ادغام بهترين روش براي بدترين حالات است. مرتب سازي سريع بهترين ميانگين را دارد. عملکرد مرتب سازي مبنا بستگي به کليد و انتخاب مبنا دارد. به ازاي n ≤ 20 مرتب سازي درجي (insertion_sort) سريعترين است. براي مقادير n بين 20 تا 45 مرتب سازي سريع (quicksort) بهترين و سريع ترين مي باشد. براي مقادير بزرگتر از n ، مرتب سازي ادغام(merge_sort ) سريع ترين مي باشد

311 10-7 خلاصه مرتب سازي داخلي مرتب سازي داخلي در هر زمان مي تواند سه بلاک (جميعا به طول 750 رکورد ) را در قالي رانش به ترتيب تا مرتب نمايد. در اين مورد مي توان از مرتب سازي سريع يا heap استقاده کرد.

312 11-7 مرتب سازي خارجي (روش هاي مرتب سازي فايل هاي بزرگ )
در زمان خواندن يا نوشتن از / به ديسک زمان هاي زيرمهم است : زمان جستجو(Seek time ) زمان تاخير (latency time ) زمان انتقال (Transmission time )

313 11-7 مرتب سازي خارجي معمولا روش مرتب سازي بر روي دستگاه هاي حافظه جانبي ، مرتب سازي ادغام است. اين روش اساسا شامل دو مرحله يا فاز مجزا است : در ابتدا ، سگمنت هاي فايل ورودي با استفاده از يک روش مرتب سازي داخلي مناسب ، مرتب مي شود. سگمنت هاي مرتب شده اصطلاحا رانش (run) ناميده مي شوند. در فاز دوم ، رانش هاي توليد شده در فاز اول بر اساس الگوي درخت ادغام ، ادغام شده و اين فرآيند تا هنگامي که تنها يک رانش باقي بماند ، ادامه پيدا مي کند.

314 11-7 مرتب سازي خارجي براي تعيين زمان مورد نياز مرتب سازي خارجي بايد موارد زير را در نظر گرفت : = حداکثر زمان جستجو = حداکثر زمان تاخير = زمان لازم براي خواندن يا نوشتن يک بلاک 250 رکوردي = مجموع = زمان لازم براي مرتب سازي داخلي 750 رکورد = زمان لازم براي ادغام n رکورد از ميانگير ورودي به ميانگير خروجي

315 11-7 ادغام k طرفه به طور کلي ادغام k طرفه بر روي m رانش حداکثر نيازمند گذر بر روي داده ها مي باشد. با افزايش درجه ادغام ، در ميزان ورودي و خروجي صرفه جويي مي شود

316 11-7 بکارگيري ميانگير براي عمليات موازي
اگر k رانش به وسيله يک ادغام k طرفه با هم ادغام شوند ، واضح است که به حداقل k ميانگير ورودي و يک ميانگير خروجي جهت انجام عمليات ادغام نياز داريم. اگر ورودي ، خروجي و ادغام داخلي به طور موازي وهمزمان انجام شود ، کافي نيست.

317 11-7 مراحل الگوريتم مربوط به ميانگير
مرحله 1 : اولين بلاک هر يک از k رانش را وارد کرده و k صف پيوندي که هر کدام داراي يک بلاک داده مي باشد را برقرار ميکنيم. k بلاک ورودي باقي مانده را به داخل يک پشته پيوندي قرار داده و بلاک هاي ورودي را آزاد کنيد. همچنين ou را برابر صفر قرار دهيد. مرحله2 : فرض کنيد lastkey[i] آخرين کليد وارد شده از رانش i باشد ، فرض کنيد که nextrun رانشي باشد که lastkey حداقل باشد. اگر ∞ + lastkey[nextrun] ≠ باشد، آنگاه بلاک بعدي از رانش nextrun را مقداردهي اوليه کنيد.

318 11-7 مراحل الگوريتم مربوط به ميانگير
مرحله3 : تابع kwaymergeرا براي ادغام رکوردهايي از k صف ورودي و قرار دادن آنها در داخل ميانگير خروجي ou مورد استفاده قرار دهيد. ادغام تا زماني ادامه مي يابد که يا ميانگير خروجي پر شود و يا رکورد ∞+ داخل ou ادغام شود. اگر در طي اين ادغام ، يکي از ميانگيرهاي ورودي ، قبل از اينکه ميانگير خروجي پر شود و يا اينکه ∞+ داخل ou ادغام گردد، خالي شود، kwaymerge بر روي همان صف به ميانگير بعدي منتقل و ميانگير خالي را به پشته ميانگيرهاي خالي برگشت مي دهد. هر چند ، اگر ميانگير ورودي در همان زمان که ميانگير خروجي پر شده يا ∞+ داخل ou ادغام گردد ، خالي شود ، آنگاه ميانگير خالي در صف باقي مانده و kwaymerge به ميانگير بعدي بر روي صف منتقل نمي شود ، مگر اينکه ادغام خاتمه يابد.

319 11-7 مراحل الگوريتم مربوط به ميانگير
مرحله4 : تا کامل شدن عمليات ورودي/ خروجي صبر کنيد. مرحله5 : اگر يک ميانگيرورودي خوانده شد ، آنرا براي رانش مناسب به صف اضافه مي کنيم. رانش بعدي را با استفاده از nextrun تعيين کنيد به نحوي که lastkey[nextrun] حداقل گردد. مرحله6 : اگر ∞ + lastkey[nextrun] ≠ باشد ، آنگاه بلاک بعدي از رانش nextrun را خوانده و ميانگير ورودي را آزاد کنيد.

320 11-7 مراحل الگوريتم مربوط به ميانگير
مرحله7 : شروع به نوشتن محتويات ميانگير خروجي ou نماييد. ou را برابر با 1- ou قرار دهيد( ou = ou – 1 ) مرحله 8 : اگر رکورد با کليد ∞ + داخل ميانگير خروجي ادغام نشده باشد ، به مرحله 3 مراجعه کنيد در غير اين صورت تا تکميل عمليات نوشتن صبر نموده و سپس الگوريتم را خاتمه دهيد.


Download ppt "ساختمان داده ها به زبان C"

Similar presentations


Ads by Google