گراف جهتدار و کاربردهای آن
تعریف گرافهای جهت دار
گراف جهت دار D، یک سه تایی مرتب((Ψ(D و (A(D و (V(D)است که تشکیل شده از یک مجموعه ناتهی V(D) از راسها و یک مجموعه (A (D مجزای از (V(Dاز کمانها و یک تابع وقوع(Ψ(D که به هر کمان D یک زوج مرتب از راسهای D- که الزاماً متمایز نیستند- را نسبت میدهد. اگر a یک کمان وu,v دو راس باشند به طوری که(u,v) = Ψ(D)(a)، آنگاه میگوئیم که u,a را به v وصل کردهاست؛ u، دم v,a سرa نامیده میشود.
میتوانیم به هر گراف جهتدار D، یک گراف G با همان مجموعه راسها متناظر کنیم، به طوری که به ازای هر کمان از D، یک یال درG با همان دو سر وجود داشته باشد. این گراف، گراف زمینه D نامیده میشود. بالعکس، میتوانیم از هر گراف دلخواه G، یک گراف جهت دار بدست آوریم بدین صورت که برای هر یال، یک ترتیب روی راسهای دو سر آن مشخص نماییم. گراف جهت دار حاصل را یک جهت دهی از G مینامیم.
گرافهای جهت دار هم، مانند گرافها، دارای یک نمایش تصویری ساده هستند. یک گراف جهت دار با نموداری از گراف زمینه آن، به علاوه پیکانهایی که سر کمان متناظر با هریال آن را مشخص میکنند، نمایش داده میشود:
هر مفهومی که برای گرافها برقرار باشد بهطور خودکار برای گرافهای جهت دار نیز معتبر خواهد بود بنابراین گراف جهت دار شکل (۱) الف همبند است و هیچ دوری به طول ۳ ندارد، زیرا گراف زمینه آن شکل (۱) ب، دارای این ویژگی هاست اما مفاهیم بسیاری وجود دارند که شامل مفهوم جهت میباشند تنها برای گرافهای جهت دار معتبرند.
یک گشت جهت دار در D عبارتست از یک دنباله متناهی ناتهی ak,uk....... ,u1 ,a1 u0)=W)، که جملههای آن یک در میان راس و کمان هستند و به ازای i=۱٬۲,….. ,k کمان ai دارای سر ui و دم ui - ۱ است.
همانند گشتها در گرافها، غالباً گشت جهت دار (u0,a1,u1,….. , ak , uk) را بهطور ساده با دنباله راسهای (u0,u1, …. , uk) نمایش میدهیم. گذرگاه جهت دار، گشت جهت داری است که گذرگاه باشد. مسیرهای جهت دار، دورهای جهت دار و تورهای جهت دار نیز بهطور مشابه تعریف میشوند.
گراف جهت داری که دارای هیچ طوقهای نیست و بین هر دو راس آن، هیچ دو کمان هم جهتی قرار ندارد یک گراف جهت دار قوی نامیده میشود.
big>مسیرهای جهت دار</big
طول مسیرها و مسیرهای جهت دار در گرافهای جهت دار، ارتباط مستقیمی با یکدیگر ندارند. این مطلب از گراف جهت دار شکل (۲) که مسیر جهت داری به طول بیشتر از یک ندارد، کاملاً مشهود است.
پرونده:Picture2.JPG
شگفت آور آن که، با نگاه به عدد رنگی یک گراف جهت دار میتوان اطلاعاتی راجع به طول مسیرهای جهت دار آن به دست آورد. قضیه زیر که متعلق به روی (۱۹۶۷) و گالای (۱۹۶۸) میباشد به توضیح این مطلب میپردازد.
قضیه (۱) گراف جهت دار D شامل مسیر جهت داری به طول۱- x است.
اثبات فرض کنید َA یک مجموعه مینیمال از کمانهای D است به طوری که D-A = َD شامل هیچ دور جهت داری نیست و فرض کنید که طول بلندترین مسیر جهت دار در َD برابر K باشد، رنگهای ۱، ۲،........ و۱+ k را به این ترتیب به راسهای َD اختصاص میدهیم که راس v دارای رنگ i است، اگر طول بلندترین مسیر جهت دار در َD با ابتدای v، برابر۱- i باشد. مجموعه راسهای به رنگ i را با Vi نمایش میدهیم، در ادامه نشان خواهیم داد که (V1,V2,….. , Vk+۱)، یک (k+۱) – رنگ آمیزی راسی مجاز از D است.
در ابتدا توجه به این مطلب ضروری است که ابتدا و انتهای هر مسیر جهت داردر َD، رنگهای متفاوتی دارند. زیرا فرض کنید که p یک (u,v) مسیر جهت دار با طول مثبت در َD و v€Vi میباشد. در این صورت یک مسیر جهت دار (v1,….. , v2 , vi)= Q در َD وجود دارد که در آنv = v1. چون َD شامل هیچ دور جهت داری نیست، PQ یک مسیر با ابتدای u و طول حداقل i میباشد. پس داریم: u€Vi.
اکنون میتوانیم نشان دهیم که دو سر هر کمانی از D رنگهای متفاوتی دارند. فرض کنید (u,v)€A (َD). اگر (u,v)€A (َD)، در این صورت (u,v) یک مسیر جهت دار در َD است و در نتیجه v,u رنگهای متفاوتی دارند. در غیر این صورت داریم: u,v)€ Aَ). با توجه به مینیمال بودن َA u,v)+ َD)شامل یک دور جهت دار در C است. در این صورت (C-(u,v یک (u,v)- مسیر جهت دار در َD بوده و بنابراین در این حالت هم، v,u رنگهای متفاوتی دارند.
بنابراین (V1,V2,....... ,Vk+۱) یک رنگ آمیزی راسی مجاز از D میباشد. در نتیجه داریم: k+۱ ≥ x و بنابراین D دارای مسیر جهت داری به طول x-۱ ≤ k است.
نتیجه بهتری که میتوان از قضیه (۱) حاصل نمود، این است که هر گراف G، دارای یک جهت دهی است که طول بزرگترین مسیر جهت دار آن x-۱ است. اگر یکx-رنگ آمیزی راسی مجاز ,….(V1, V2, Vx) از G داده شده باشد، Gرا بدین صورت جهت دهی میکنیم: u€Vi و v€Vj با شرط i ≤j، یال uv را به کمان (u,v) تبدیل میکنیم. واضح است که در این جهت دهی از G، هیچ مسیر جهت داری نمیتواند بیش از x راس داشته باشد زیرا هیچ دوراس از مسیر نمیتوانند همرنگ باشند.
یک جهت دهی از گراف کامل را یک تورنمنت مینامیم. تورنمنتهای چهار راسی، در شکل (۳) نشان داده شدهاند. هریک از این تورنمنتها را میتوان به عنوان نتایج بازیهای یک مسابقه دورهای بین چهار بازیکن در نظر گرفت. بهطور مثال تورنمنت اول در شکل (۳) نشان میدهد که یک بازیکن، هر سه بازی خود را برنده شدهاست و دیگر بازیکنان، هر کدام، فقط یک برد دارند.
پرونده:Picture3.JPG
یک مسیر همیلتنی جهت دار از D، مسیر جهت داری است که تمام راسهای D را شامل میگردد. بلافاصله از قضیه(۱) نتیجه میشود که هر تورنمنت دارای چنین مسیری است. این مطلب نخستین بار توسط ریدی (۱۹۳۴) اثبات شد.
قضیه (۲) گراف جهت دار بدون طوقه D، دارای مجموعه مستقلی مانند S است. به طوری که هر راس D که در S نیست، توسط مسیر جهت داری به طول حداکثر ۲، از یک را س S قابل دستیابی است.
اثبات از استقراء روی v استفاده میکنیم. درستی قضیه به ازای v=۱ بدیهی است. فرض کنید که قضیه به ازای تمام گرافهای جهت دار با کمتر از vراس برقرار باشد و v را یک راس دلخواه D در نظر بگیرید. طبق فرض استقراء مجموعه مستقلی مانند َS در((D-({v} UN(v که در این رابطه Nمثبت است، وجود دارد به طوری که هر راس َD که در َS نیست، توسط مسیر جهت داری به طول حداکثر ۲، از یک راس َS قابل دستیابی است. اگر v یک همسایه خروجی از راسی مانند uدرَS باشد، آنگاه هر راس از(N(v با مسیر جهت داری به طول ۲ از u قابل دستیابی است. بنابراین در این حالت، َS = Sویژگی مورد نظر را داراست. از طرف دیگر، اگر v همسایه خروجی هیچ راسی از َS نباشد، در این صورت v به هیچ راسی از َS متصل نیست و مجموعه مستقل { S = َS U { v دارای ویژگی مورد نظر خواهد بود.
نتیجه: هر تورنمنت شامل راسی است که تمام راسهای دیگر با مسیر جهت داری به طول حداکثر ۲ از آن قابل دستیابی میباشند. اثبات اگر D یک تورنمنت باشد، آنگاه α=۱.
big>دورهای جهت دار</big
با استفاده از نتیجه قضیه (۱) اگر فرض کنیم که تورنمنت قویا همبند است (توضیح: قویاً همبند یعنی دو راس از یک گراف طوری باشند که هریک از دیگری قابل دستیابی باشد.) میتوانیم نتایج قویتری را بدست آوریم.
قضیه زیر متعلق به مون (۱۹۹۶) است. اگر S و T، زیر مجموعههایی از V باشند، مجموعه کمانهایی که از D که دم آنها درS و سر آنها در T باشد، با (S,T) نمایش میدهیم.
قضیه (۳) هر راس از یک تورنمنت قویاٌ همبند D با ۳ ≤ v، درون یک –k دور جهت دار با شرطk ≤v و k ≤۳قرار دارد. اثبات: فرض کنید D یک تورنمنت قویاٌ همبند با شرط ۳ ≤ v و u یک راس دلخواه D باشد. قرار میدهیم(S=N(u که در آن Nدرجهت مثبت است و(T=N(uکه در آن Nدرجهت منفی است ابتدا نشان میدهیم که u درون یک ۳- دور جهت دار قرار دارد چون D قویاٌ همبند است، S,T هیچکدام نمیتوانند تهی باشند و به همین علت، (S,T) باید ناتهی باشد (شکل۴) بنابراین کمانی مانند (v,w) با شرطv€S وw€T وجود دارد و u در ۳- دور جهت دار (u,v,w,u) قرار میگیرد. پرونده:Picture4.JPG
اینک قضیه را با استقرار روی k اثبات میکنیم. فرض کنید uدرون دورهای جهت دار به هریک از طولهای ۳ تا n قرار داشته باشد (n ≤v). در ادامه نشان خواهیم داد که u در یک (n+۱) – دور جهت دار نیز قرار دارد. فرض کنید(C=(v, v1............. ,vn یک n -دور جهت دار باشد که در آن v۰=vn=u اگر راسی مانند v در V(D)\V(C) وجود داشته باشد که سر یک کمان که دم آن روی C است و دم دیگری که سر آن روی C است باشد در این صورت راسهای مجاور vi و vi+۱ روی C وجود دارند به طوری که (vi,v) و (v,vi+۱) کمانهایی از D هستند. در این حالت، u درون (n+۱)- دور جهت دار (v0,v1,……, vi, v, vi+۱,….vn) قرار دارد.
در غیر این صورت، مجموعه راسهایی از (V(D)\V(Cکه سر کمانهای متصل به C هستند را با S و مجموعه راسهایی از(V(D)\V(C که دم کمانهای متصل به Cهستند را با T نمایش میدهیم. شکل (۵)
پرونده:Picture5.JPG
همانند حالت قبل، با توجه به اینکه D قویا همبند است، S,T و (S,T) همگی ناتهی هستندو کمانی مانند (v,w) در D با شرط S v وT w وجود دارد. بنابراین u درون (n+۱)- دور جهت دار (v0,v,w,v2,……,vn) قرار دارد. یک دور همیلتنی جهت دار از D، دور جهت داری است که تمام راسهای D را شامل میشود با توجه به قضیه (۳) هر تورنمنت قویا همبند، شامل چنین دوری است. این مطلب را نخستین بار، کمیون ۱ اثبات کرد.
big>کاربردهای گراف جهت دار</big
۱-طراحی یک استوانه کامپیوتری کارآمد
۲-یک طرفه کردن جادهها: یک طرفه کردن سیستم جادهای به طوری که آرایش ترافیک تا حد ممکن حفظ شود.
۳-رتبه بندی شرکت کنندگان در یک تورنمنت
در یک تورنمنت تنیس، تعدادی بازیکن شرکت دارند که هر بازیکن با تمام بازیکنان دیگر مسابقه میدهد. اگر نتایج بازیها را داشته باشیم، چگونه میتوانیم بازیکنان را رتبه بندی کنیم؟ بهطور مثال، تورنمنت شکل (۶) را در نظر بگیرید. این تورنمنت نتایج بازیهای بین شش بازیکن را نشان میدهد بازیکن ۱، بازیکنان ۲، ۴، ۵، ۶ را شکست داده و مغلوب بازیکن ۳ شدهاست و الی آخر.
یک راه ممکن برای رتبه بندی بازیکنان این است که یک مسیر همیلتنی جهت دار در تورنمنت پیدا کنیم. (با توجه به نتیجه قضیه (۱) چنین مسیری حتماً وجود دارد.) سپس با توجه به موقعیت بازیکنان در این مسیر، آنها را رتبه بندی میکنیم. به عنوان مثال، مسیر همیلتنی جهت دار (۶، ۵، ۴، ۲، ۱، ۳) مشخص میکند که بازیکن ۳، قهرمان و بازیکن ۱ نایب قهرمان است و به همین ترتیب. البته این روش رتبه بندی، در عمل دچار مشکل میشود، زیرا یک تورنمنت در حالت کلی تعداد زیادی مسیر همیلتنی جهت دار دارد. درمثال فوق، مسیرهای (۳، ۶، ۵، ۴، ۲، ۱)، (۵، ۲، ۳، ۶، ۴، ۱) و غیره نیز در تورنمنت وجود دارند.
روش دیگر آن است که امتیازها (تعداد بازیکنهای برده توسط هر بازیکن) را محاسبه کرده، آنها را با هم مقایسه کنیم. اگر این کار را برای مثال بالا انجام دهیم به بردار امتیاز زیر میرسیم. (۱، ۲، ۲، ۳، ۳، ۴)= S1
مشکلی که در اینجا پدیدار میشود آنست که این بردار امتیاز، بین بازیکنهای ۲و ۳ تمایزی قائل نیست در حالی که بازیکن ۳ بازیکنانی با امتیازات بیشتر را شکست داده است. با توجه به این مطلب از بردار امتیاز مرتبه دوم زیر استفاده میکنیم. (۸،۵،۹،۳،۴،۳)= S2
که در این بردار، امتیاز مرتبه دوم هر بازیکن عبارت است از مجموع امتیازات بازیکنانی که از این بازیکن شکست خوردهاند. در این حالت بازیکن ۳ رتبه اول را کسب میکند. با ادامه دادن این فرا یند، بردارهای دیگر به صورت زیر به دست میآیند.
(۱۵،۱۰،۱۶،۷،۱۲،۹)= S۳=(۳۸،۲۸،۳۲،۲۱،۲۵،۱۶) S4
منابع
- . نظریه گراف و کاربردهای آن (نویسنده جی. ای. باندی و یو. اس. مورتی) مترجم:حمیدضرابی زاده