1 / 14

بسم الله الرحمن الرحيم ساختمان داده‌ها

بسم الله الرحمن الرحيم ساختمان داده‌ها. گراف. جلسه دوازدهم 92/10/14. تعریف گراف. 2. یک گراف G شامل دو مجموعه V و E است که به صورت G(V, E) نمایش داده می‌شود . V : یک مجموعه محدود و ناتهی از رئوس (Vertices) است.

Download Presentation

بسم الله الرحمن الرحيم ساختمان داده‌ها

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. بسم الله الرحمن الرحيمساختمان داده‌ها گراف جلسه دوازدهم 92/10/14

  2. تعریف گراف 2 گراف • یک گراف G شامل دو مجموعه V و E است که به صورت G(V, E) نمایش داده می‌شود. • V : یک مجموعه محدود و ناتهی از رئوس (Vertices) است. • E : یک مجموعه محدود از زوج رئوس که به آنها یال (Edge)می‌گویند. • گراف می‌تواند غیر جهت دار یا جهت دار باشد. • در گراف غیر جهت دار یال را با زوج (u,v) و در گراف جهت دار با زوج <u,v> نمایش می‌دهیم. یعنی در گراف جهت دار <u,v> ≠ <v,u> و در گراف غیر جهت دار (u,v) = (v,u). • زیرگراف: هر زیر مجموعه از مجموعه رئوس V و مجموعه یال‌های E را زیر گراف گراف G می‌نامیم.

  3. ویژگیهای گراف 0 0 1 1 2 2 1 1 0 0 2 2 3 گراف در یک گراف یال‌هایی که ابتدا و انتهای آنها یک راس باشد مجاز نیست. به چنین یالهایی self edgeیاself loop می‌گویند. به گرافی که دارای یال حلقه ای باشد گراف خود حلقه ای گفته می‌شود. در گراف یال موازی مجاز نیست. اگر موجود باشد به آن گراف چندگانه می‌گویند.

  4. تعداد یالها در گراف 4 گراف حداکثر تعداد یالها در گراف غیر جهت دار با n راس برابر با n(n-1)/2می‌باشد. حداکثر تعداد یالها در گراف جهت دار با n راس برابر با n(n-1)می‌باشد. اگر در گراف دلخواه G درجه تمامی رئوس را بدانیم، آنگاه تعداد یالها بر حسب درجه رئوس برابر است با:

  5. تعاریف گراف 5 گراف • یک گراف غیرجهتدار با n(n-1)/2 یال را گراف کامل گویند. • در گراف جهت دار درجه یک راس برابر است با: درجه ورودی + درجه خروجی. • درجه ورودی: تعداد یال‌هایی که به راس وارد می‌شود. • درجه خروجی: تعداد یال‌هایی که از راس خارج می‌شود. • درجه هر گراف برابر با بزرگ‌ترین درجه از بین گره‌های آن گراف است. • اگر درجه راسی فرد باشد آن راس را فرد و اگر زوج باشد آن راس را زوج گویند. • گراف مکمل گراف G گرافی است که هیچ یال مشترکی با گراف G نداشته باشد ولی رئوس مشترک دارند.

  6. مفاهیم گراف 0 1 2 3 4 5 6 گراف • رئوس مجاور هم (adjacent vertices): رئوس واقع شده بر یک یال را گویند. • مسیر (path):یک مسیر از u به v در گراف G‌ ترتیبی از رئوس u,i1,i2,…ik,v است بطوریکه (u,i1) , (i1,i2) , … ,(ik,v) یالهای گراف باشند. اگر گراف جهت دار باشد باید <u,i1> , <i1,i2> , … ,<ik,v> یالهای گراف باشند. • مانند : 2,4,5,3,0 • طول مسیر: تعداد یالهای واقع شده بر مسیر را گویند. • طول مسیر 2,4,5,3,0 برابر 4است. • مسیر ساده (simple path): مسیری که در آن تمامی رئوس به جز احتمالاً اولین و آخرین آنها مجزا و غیر تکراری است. • مانند 2,5,1,0,3

  7. مفاهیم گراف 0 1 2 3 4 5 7 گراف • چرخه (cycle): مسیر ساده ای که اولین و آخرین راس در آن یکسان باشد. • مانند 2,5,1,0,2 • در گراف بدون جهت دو راس دلخواه u و v را متصلمی‌گوییم، اگر مسیری از u به v یا بالعکس وجود داشته باشد. • گراف بدون جهت را متصل یا همبند گوییم، اگر برای هر دو راس u و v مسیری از u به v یا بالعکس وجود داشته باشد.

  8. نمایش گراف با استفاده از ماتریس مجاورت اگر یال (i,j) یا <i,j> موجود باشد 0 0 در غیر این صورت 2 2 1 1 3 3 8 گراف • برای گراف G=(V,E) با n≥1راس، ماتریس مجاورتی به صورت آرایه دو بعدی زیر تعریف می‌شود. • مثال:

  9. پیمایش گراف 9 گراف • فرض کنید گراف G=(V,E) و راس v در V را داریم. می‌خواهیم تمامی رئوسی را که درG از طریق v قابل دسترس است را ملاقات کنیم. دو روش وجود دارد: • جستجوی عمقی (depth first search) • جستجوی سطحی (breadth first search) • پیمایش گراف منجر به درخت پوشا می‌شود. درخت پوشای گراف G درختی است که n راس گراف را داشته باشد اما دقیقا n-1یال را انتخاب کند.

  10. جستجوی عمقی (DFS) 0 1 2 3 0 4 5 1 2 3 4 5 10 گراف با راس v شروع کرده سپس یک راس مجاور v که ملاقات نشده را انتخاب و الگوریتم را برای آن تکرار می‌کنیم. وقتی به راسی می‌رسیم که تمامی رئوس مجاورش ملاقات شده، آنگاه به آخرین رأسی برمی‌گردیم که دارای راس مجاور ملاقات نشده باشد. مثال: گراف‌های زیر را به روش عمقی پیمایش کنید.

  11. جستجوی سطحی (BFS) 0 0 1 1 2 2 3 3 4 4 5 5 11 گراف • با راس v شروع کرده سپس تمامی رئوس مجاور vکه ملاقات نشده را ملاقات می‌کنیم. پس از آن رئوس ملاقات نشده مجاور با رئوس مجاور v را ملاقات می‌کنیمو تا هنگامیکه همه گره‌ها ملاقات شوند این کار را ادامه می‌دهیم. • مثال: گراف‌های مقابل را به روش سطحی پیمایش کنید.

  12. درخت پوشای کم هزینه 12 گراف • گرافی که در آن یال‌ها دارای وزن باشند، گراف وزن‌دارنامیده می‌شود. • برای بدست آوردن درخت پوشایی که دارای کمترین هزینه باشد از الگوریتم‌های خاصی استفاده می‌شود، که تمام این الگوریتم‌ها بر دو اصل پیاده سازی می‌شوند: • همیشه در هر مرحله یالی را انتخاب می‌کنیم که کمترین وزن را با مسیر انتخاب شده تا به حال داشته باشد. • همیشه یالی انتخاب می‌کنیم که با مسیر انتخاب شده تا به حال، دور ایجاد نکند.

  13. الگوریتم کروسکال 13 گراف در الگوریتم کروسکال (Kruskal) یال‌های گراف را به ترتیب صعودی مرتب می‌کنیم. از اولین (کوچکترین) یال شروع کرده و هر یال را به گراف اضافه می کنیم به شرط اینکه دور در گراف ایجاد نگردد. این روال را آنقدر ادامه می دهیم تا درخت پوشای بهینه تشکیل گردد. در هر مرحله از الگوریتم کروسکال ممکن است درختها متصل نباشند. مثال: درخت پوشای مینیمم گراف مقابل را با استفاده از الگوریتم کروسکال بدست آورید.

  14. الگوریتم پریم 14 گراف در روش پریم (prim) از یک رأس شروع می کنیم و یال با کمترین وزن که از آن می گذرد را انتخاب می کنیم. در مرحله بعد یالی انتخاب می‌شود که کمترین وزن را در بین یال‌هایی که از دو گره موجود می‌گذرد داشته باشیم. این روال را آنقدر تکرار می کنیم تا درخت پوشای بهینه حاصل شود. باید توجه کرد که یال انتخابی در هر مرحله در صورتی انتخاب می‌شود که در گراف دور ایجاد نکند.  تفاوت روش پریم با روش کراسکال در این است که گراف حاصل در مراحل میانی روش پریم همیشه متصل است ولی در الگوریتم کراسکال در آخرین مرحله قطعاً متصل است.

More Related