مسئله کم‌هزینه‌ترین جریان

از testwiki
پرش به ناوبری پرش به جستجو

مسئله کم‌هزینه‌ترین جریان، پیدا کردن کم‌هزینه‌ترین راه فرستادن میزان مشخصی از جریان درون یک شبکه شاره است. حل این مسئله در زندگی روزمره کاربردهایی دارد از جمله شبکه‌های هزینه‌دار (مانند شبکه‌های مخابراتی) و هم‌چنین در مواردی که تناسب آن با مسئله خیلی مشهود نیست، مانند تعیین محل قرارگیری انبارها.

تعریف

یک شبکه شاره داریم که آن را با گراف جهت‌دار G=(V,E) با مبدا sV و مقصد tV که در آن یال (u,v)E دارای ظرفیت c(u,v)>0، جریان f(u,v)0 و هزینه a(u,v) می‌باشد، نشان می دهیم (اکثر الگوریتم‌های کم‌هزینه‌ترین جریان یال با هزینه منفی را پشتیبانی می‌کنند.) هزینه فرستادن این جریان f(u,v)a(u,v) است. شما باید جریان d را از s به t بفرستید.

تعریف مسئله کمینه کردن هزینه کل جریان است:

(u,v)Ea(u,v)f(u,v)

با شرط‌های زیر:

محدودیت ظرفیت: f(u,v)c(u,v)
تقارن یک‌سویه: f(u,v)=f(v,u)
بقای جریان: wVf(u,w)=0 for all us,t
جریان خواسته‌شده: wVf(s,w)=d and wVf(w,t)=d

ارتباط با مسئله‌های دیگر

حالت دیگری از این مسئله پیدا کردن جریان بیشینه‌ای است که بین جریان‌های بیشینه کم‌ترین هزینه را دارد که می‌توان آن را مسئله کم‌هزینه‌ترین بیشینه جریان نامید. این حالت در پیدا کردن کم‌هزینه‌ترین تطابق بیشینه کاربرد دارد.

در بعضی راه‌حل‌ها پیدا کردن کم‌هزینه‌ترین بیشینه جریان ساده است. در غیر این صورت، می‌توان از جستجوی دودویی روی d استفاده کرد.

می‌توان از مسئله کم‌هزینه‌ترین گردش در حل این مسئله استفاده کرد. این کار با صفر قرار دادن کران پایین همه‌ی یال‌ها، اضافه کردن یک یال از مقصد t به مبدا s با ظرفیت c(t,s)=d و کران پایین l(t,s)=d و قرار دادن کل جریان برابر d انجام می‌شود.

دو مسئله زیر حالات خاص این مسئله به شمار می آیند:

راه‌حل‌ها

از آنجایی که ما تابعی خطی را بهینه میکنیم و تمام شروط خطی اند، این مسئله با استفاده از برنامه‌ریزی خطی قابل حل است.

علاوه بر آن الگوریتم‌های ترکیبیاتی مختلفی نیز وجود دارند، برای بررسی جامع تر، الگو:Ref را ببینید. تعدادی از آن‌ها تعمیم الگوریتم بیشینه جریان هستند، بقیه روش‌های کاملاً متفاوتی استفاده میکنند.

الگوریتم‌های اساسی شناخته شده (حالت‌های زیادی دارند):

کاربرد

کم وزن ترین تطابق بیشینه دو بخشی

کاهش مسئله کم وزن ترین تطابق بیشینه دو بخشی به مسئله کم هزینه ترین بیشینه جریان

در گراف دو بخشی G=(AB,E)، میخواهیم تطابق بیشینه با کمترین هزینه را بیابیم. w: ER را تابع وزن یال‌های گراف در نظر بگیرید. هدف از مسئله کم وزن‌ترین تطابق بیشینه دو بخشی یا مسئله تخصیص، پیدا کردن یک تطابق کامل ME است که مجموع وزن‌هایش کمینه باشد. میخواهیم این مسئله را به یک مسئله شبکه شاره کاهش دهیم.

G=(V=AB,E=E) را در نظر بگیرید. ظرفیت تمام یال‌های E را 1 بگذارید. رأس مبدا s را اضافه کرده و به تمام رئوس A متصل میکنیم و رأس مقصد t را اضافه کرده و تمام رئوس B را به آن متصل میکنیم. ظرفیت تمام یال‌های جدید را یک و هزینه آن‌ها را صفر در نظر میگیریم. ثابت می‌شود که یک کم وزن‌ترین تطابق دو بخشی در G موجود است اگر و فقط اگر یک کم هزینه‌ترین جریان در G وجود داشته باشد.الگو:Ref

جستارهای وابسته

پانویس‌ها و منابع

  1. الگو:Noteالگو:Cite book
  2. الگو:Noteالگو:Cite journal
  3. الگو:Noteالگو:Cite journal
  4. الگو:Noteالگو:Cite journal
  5. الگو:Noteالگو:Cite journal
  6. الگو:Noteالگو:Cite journal

پیوندهای کمکی