الگوریتم مقیاس‌دهی گبو برای کوتاه‌ترین مسیرها از یک مبدأ واحد

از ویکی‌پدیا، دانشنامهٔ آزاد

الگوریتم مقیاس دهی گبو برای کوتاهترین مسیرها از یک مبدأ واحد
(به انگلیسی: (Gabow's algorithm (single-source shortest paths) الگوریتم مقیاس دهی ابتدا با در نظر گرفتن فقط بالاترین بیت یک مقدار ورودی مناسب (مانند وزن یال‌ها)، مسئله را حل می‌کند. سپس جواب اولیه را با نگاه کردن به دو بیت اول پالایش می‌کند. به همین ترتیب بیت‌های بیشتر و بیشتری را در نظر می‌گیرد و در هر بار جواب را پالایش می‌کند تا این که همه بیت‌ها در نظر گرفته شوند و جواب صحیح محاسبه شود. دراین مسئله، الگوریتم محاسبه کوتاهترین مسیرها از یک مبدأ واحد را به وسیله مقیاس دهی وزن یال‌ها بررسی می‌کنیم. گراف جهت دار با وزن‌های صحیح غیر منفی داده شده‌است. فرض کنید هدف، ایجاد الگوریتمی است که در زمان اجرا می‌شود. فرض می‌کنیم که همه راس‌ها از مبدأ قابل دستیابی‌اند. الگوریتم در نمایش دودویی وزن‌های یال‌ها، هربار یک بیت را به ترتیب با ارزش‌ترین بیت، وارد حل مسئله می‌کند. به ویژه فرض کنید ، تعداد بیت‌ها در نمایش دودویی باشد و برای . به عبارت دیگر، شکل "کوچک شده " است که به وسیله با ارزش‌ترین بیت، تولید می‌شود. (بنابراین برای همه داریم، . بعنوان مثال اگر وباشد آنگاه است. را به عنوان وزن کوتاهترین مسیر از راس به راس با استفاده از تابع وزن تعریف می‌کنیم؛ بنابراین برای همه داریم . برای مبدأ الگوریتم مقیاس دهی ابتدا وزنهای کوتاهترین مسیر را برای همه . محاسبه می‌کند، سپس برای همه و. را محاسبه می‌کند و به همین ترتیب ادامه می‌دهد تا این که برای همه δ_k (u_,v)v∈V محاسبه شود. فرض می‌کنیم است و خواهیم دید که محاسبه به اندازه ، و لذا کل الگوریتم به اندازه زمان می‌برد.

مراحل
  • فرض کنید برای همه راس‌های داریم نشان دهید برای همه می‌توانیم را در زمان محاسبه کنیم.
  • نشان دهید برای همه می‌توانیم را در زمان محاسبه کنیم.

اکنون به محاسبه از می‌پردازیم.

  • ثابت کنید برای هر داریم یا .

سپس ثابت کنید که برای همه داریم

  • برای و تعریف زیر را داریم

ثابت کنید برای و همه, یال یعنی مقدار وزن جدید آن یال، یک عدد صحیح غیر منفی است.

  • اینک را به عنوان وزن کوتاهترین مسیر از به با استفاده از تابع وزن تعریف می‌کنیم. ثابت کنید برای و همه داریم

و


  • نشان دهید چگونه برای همه می‌توان را از در زمان به دست آورد و نتیجه بگیرید که برای همه , می‌تواند در زمان محاسبه گردد.

منابع[ویرایش]

پیوند به بیرون[ویرایش]