فهرست همسایگی

در نظریهُ گراف یک فهرست همسایگی نمایش همهٔ یال‌های یک گراف به صورت مجموعه‌ای از فهرست‌هاست، اگر گراف بدون جهت باشد، هر واحد از این فهرست‌ها یک مجموعه از دو گره شامل دو سر یال مربوطه است.

کاربرد در علوم رایانه

شکل 1
شکل 2

نمایش فهرست همسایگی یک گراف (G=(V,E شامل یک آرایه‌ی Adj از |V| فهرست است، یعنی به ازای هر رأس در V یک فهرست. برای هر رأس u در مجموعه رأس‌های V، فهرستِ همسایگی [Adj[u شامل همهٔ رأس‌های v است به طوری که یال (u,v) در E وجود داشته باشد. به عبارتی دیگر، [Adj[u دربردارندهٔ همهٔ رأس‌هایی است که یک یال از u به آن‌ها در گراف G وجود دارد. این رأس‌ها در فهرست همسایگی با ترتیبی دلخواه چیده شده‌اند. شکل 1.b نمایش فهرست همسایگیِ گراف بدون جهتِ نشان داده شده در شکل 1.a است. مشابهاً شکل 2.b نمایش فهرست همسایگی گرافِ جهت‌دار نشان داده شده در شکل 2.a است.

خصوصیات فهرست همسایگی

اگر G یک گراف جهت‌دار باشد، مجموع طول‌های همه‌ی فهرست‌های همسایگی برابر با |E| است، چرا که یالی به شکل (u,v) با ظاهر شدنِ v در[Adj[u نمایش داده می‌شود. اما اگر G بدون جهت باشد، مجموع طول‌های همه‌ی فهرست‌های همسایگی برابر با «دوبرابرِ» |E|است، چرا که یالی بدون جهت به شکل (u,v) با ظاهر شدنِ v در [Adj[u و u در [Adj[v نمایش داده می‌شود. برای هر دو حالت (جهت دار و بدون جهت)، فهرست همسایگی ویژگی مطلوبی دارد و آن اینکه حافظهٔ مورد نیاز آن(Ѳ(V+E است.

نارسایی‌های فهرست همسایگی

یک اشکال عمدهٔ فهرست‌های همسایگی این است که راه سریع تری برای اینکه بدانیم یال داده شدهٔ (u,v) در گراف هست یا نه، وجود ندارد جزاینکه در فهرست [Adj[u به دنبال v بگردیم. این اشکال می‌تواند با استفاده از نمایش ماتریس همسایگی گراف اصلاح شود اما به هزینهٔ استفاده از حافظهٔ بیشتر!

منابع

  • توماس اچ کورمن, Charles E. Leiserson, رونالد ریوست, and کلیفورد استین (2001), "Chapter 26", مقدمه‌ای بر الگوریتم‌ها (2nd edition ed.), MIT Press and McGraw-Hill, p. 696–697, ISBN 0-262-03293-7
This article is issued from Wikipedia. The text is licensed under Creative Commons - Attribution - Sharealike. Additional terms may apply for the media files.