دور (نظریه گراف)
در نظریه گراف، دور (به انگلیسی: Cycle) گرافی است که تعداد برابری از یال و رأس دارد، بهطوریکه رئوس میتوانند روی یک دایره قرار بگیرند و هر دو رأس این گراف مجاورند، اگر و تنها اگر روی دایرۀ بهصورت متوالی قرار گرفته باشند. بهعبارت دقیقتر، در یک گراف با مجموعه رئوس V و مجموعه یالهای E، یک دور عبارت است از دنبالهای بهشکل ( و ) که و بهجز این دورِ رأس در دنباله همۀ رئوس و همۀ یالها غیرتکراری باشند.
تشخیص دور
ویرایشپیدا کردن دور یا تشخیص وجود آن در گراف بدونِ جهت و گراف جهتدار به وسیله جستجوی عمق اول امکانپذیر است. یال برگشت (به انگلیسی: Back Edge) به یالی مانند e گفته میشود که از رأس u - که در مرحله کنونی اجرای الگوریتم در آن مشغول جستجو هستیم - به رأسی مانند v باشد، در حالیکه که v یکی از اجداد u است. حال اگر جستجوی عمقِ اوّل در حین اجراء به یک یال برگشت و برخورد، نشاندهندۀ این است که گراف شامل حداقّل یک دور است. در صورتی هم که هیچ یال برگشتی وجود نداشته باشد، گراف فاقد دور است. در گراف همبند بدون جهت با مجموعۀ رئوس V زمانِ اجرای این الگوریتم برای پیدا کردن دور از است زیرا حداکثر یال از این گراف میتوانند متعلق به یک درخت باشند و اگر بیش از این تعداد یال وجود داشته باشد، گراف دور دارد.
روشِ دیگر برای تشخیص دور در گرافِ ساده استفاده از دادهساختار مجموعههای مجزا یا همان دادهساختار ادغام-جستجو (به انگلیسی: Union-Find) است که به اِزای هر یال e که بین دو راس u و v قرار گرفتهاست، اگر نتیجهٔ جستجو u و v یکسان بود؛ یعنی از قبل در مؤلفه یکسانی بودند و e یک دور ایجاد خواهد کرد و دور پیدا شده است، در غیر این صورت مؤلفه دو رأس را با هم ادغام میکنیم.[۱]
دور منفی
ویرایشهمچنین، در گراف وزندار دور منفی به دوری گفته میشود که مجموع وزن یالهای تشکیلدهندهٔ آن عددی منفی شود. وجود دور منفی اهمیّت زیادی در مسائل یافتن کوتاهترین مسیر دارد زیرا اگر در گراف وزنداری دور منفی وجود داشته باشد، میتوان هزینۀ رسیدن از رأسی به رأس دیگر را با انجام یک پیمایش (به انگلیسی: Walk) بیشتر کاهش داد. در چنین حالتی، پیدا کردن جواب مسئله کوتاهترین مسیر در زمان چندجملهایی راه حلی ندارد. دلیل آن هم این است که میتوان به هر یالِ یک گراف G، وزن ۱- نسبت داد و گراف 'G را به دست آورد که در این صورت پیدا کردن کوتاهترین مسیر در گراف 'G (که ممکن است دور منفی داشته باشد) همارز پیدا کردن طولانیترین مسیر در گراف G است و میدانیم که پیدا کردن طولانیترین مسیر یک مسئله NP-Hard است. در نتیجه، مسئلهٔ پیدا کردن کوتاهترین مسیر در گرافی با دورِ منفی راهحلّ چندجملهایی ندارد، مگر آنکه ثابت شود. (P=NP)
با توجه به مشکلاتی که وجود دور منفی را برای پیدا کردن کوتاهترین مسیر در گراف ایجاد میکند، برخی از الگوریتمهای این مسئله مانند الگوریتم بلمن-فورد یا الگوریتم فلوید-وارشال میتوانند وجود دور منفی در گراف را تشخیص دهند.
همچنین، در برخی از کاربردها، وجود یک دور منفی معادلِ وجود یک بنبست (به انگلیسی: Deadlock) در سیستم است که تشخیص وجود آن اهمیّت دارد.
منابع
ویرایش- B.West, Douglas (2002). "Fundamental Concepts". Introduction to Graph Theory (به انگلیسی). Pearson Education.
- http://cstheory.stackexchange.com/questions/17462/finding-the-shortest-path-in-the-presence-of-negative-cycles
- https://en.wiki.x.io/wiki/Floyd–Warshall_algorithm
- https://en.wiki.x.io/wiki/Bellman–Ford_algorithm