حساب کاربری
​
تغیر مسیر یافته از - الگوریتم دکسترا
زمان تقریبی مطالعه: 7 دقیقه
لینک کوتاه

الگوریتم دایکسترا

در نظریه گراف، الگوریتم دایکسترا (به انگلیسی: Dijkstra's algorithm) یکی از الگوریتم‌های پیمایش گراف است که توسط دانشمند هلندی علوم رایانه، اِدْسْخِر دیْکْسْترا در سال ۱۹۵۹ ارائه شد.

الگوریتم دایکسترا
اجرا الگوریتم دیکسترا
ردهالگوریتم جستجو
ساختمان دادهگراف
کارایی بدترین حالت O ( | E | + | V | log ⁡ | V | )

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

الگوریتم دایکسترا یکی از الگوریتم‌های مورد استفاده برای محاسبه کوتاه‌ترین مسیر تک منبع (single-source shortest path) است و مشابه الگوریتم پریم می‌باشد در صورتی که گراف یال با وزن منفی داشته باشد، این الگوریتم درست کار نمی‌کند و می‌بایست از الگوریتم‌های دیگر نظیر الگوریتم بلمن-فورد که پیچیدگی زمانی آن‌ها بیشتر است استفاده کنیم.

خط مشی الگوریتم دایکسترا، مشابه با روش حریصانهٔ استفاده شده در الگوریتم پریم برای پیدا کردن زیر درخت فراگیر بهینه است.

فهرست

  • ۱ نام‌گذاری
  • ۲ روند
  • ۳ این الگوریتم چگونه کار می‌کند؟
  • ۴ الگوریتم
    • ۴.۱ پیاده‌سازی
    • ۴.۲ پیچیدگی زمانی
  • ۵ کاربردها
  • ۶ منابع
  • ۷ پیوند به بیرون

نام‌گذاری

نام این الگوریتم بر اساس نام ارائه‌دهنده هلندی آن، یعنی اِدسخِر دایکسترا انتخاب شده‌است. در منابع فارسی آن را به شکل‌های دِیکسترا، دکسترا، دایکسترا، دایجسترا، دیجسترا، دایجکسترا و دیجکسترا هم نوشته شده‌است، ولی جیمِ آن در تلفظ هلندی آن تلفظ نمی‌شود، لذا دو مورد اول صحیح هستند.

روند

روند الگوریتم دایکسترا مطابق زیر می‌باشد:

۱- انتخاب راس مبدا

۲- مجموعهٔ S، شامل رئوس گراف، معین می‌شود. در شروع، این مجموعه تهی بوده و با پیشرفت الگوریتم، این مجموعه رئوسی که کوتاه‌ترین مسیر به آن‌ها یافت شده‌است را در بر می‌گیرد.

۳- راس مبدأ با اندیس صفر را در داخل S قرار می‌دهد.

۴- برای رئوس خارج از S، اندیسی معادل، طول یال + اندیس راس قبلی، در نظر می‌گیرد. اگر راس خارج از مجموعه دارای اندیس باشد، اندیس جدید کمترین مقدار از بین اندیس قبلی و طول یال + اندیس راس قبل، می‌باشد.

۵- از رئوس خارج مجموعه، راسی با کمترین اندیس انتخاب شده و به مجموعهٔ S اضافه می‌گردد.

۶- این کار را دوباره از مرحلهٔ ۴ ادامه داده تا راس مقصد وارد مجموعهٔ S شود.

در پایان اگر راس مقصد دارای اندیس باشد، اندیس آن نشان دهندهٔ مسافت بین مبدأ و مقصد می‌باشد. در غیر این صورت هیچ مسیری بین مبدأ و مقصد موجود نمی‌باشد.

همچنین برای پیدا کردن مسیر می‌توان اندیس دیگری برای هر راس در نظر گرفت که نشان دهندهٔ راس قبلی در مسیر طی شده باشد. بدین ترتیب پس از پایان اجرای الگوریتم، با دنبال کردن رئوس قبلی از مقصد به مبدا، کوتاه‌ترین مسیر بین دو نقطه نیز یافت می‌شود.

این الگوریتم چگونه کار می‌کند؟

در حین اجرای الگوریتم دو چیز به‌طور ضمنی نگهداری می‌شود. یکی مجموعهٔ S

از رأس‌هایی که وزن کوتاه‌ترین مسیر از مبدأ تا آن‌ها مشخص شده و دیگری دنبالهٔ d
که برای هر رأس v
، مقدار d v
برابر وزن کوتاه‌ترین مسیر از مبدأ تا v
است به شرطی که تمام رأس‌های این مسیر به جز v
از رئوس داخل S
باشند. S
در ابتدا تهی و مقادیر d
برای همهٔ رئوس به غیر از مبدأ بی‌نهایت است و مقدار آن برای مبدأ صفر گذاشته می‌شود. الگوریتم در هر مرحله رأسی خارج S
را که d
برای آن کمترین است انتخاب و به مجموعهٔ S
اضافه می‌کند و سپس مقادیر d
را برای رئوس همسایهٔ آن رأس به‌روز می‌نماید. در صورتی که نیاز به تشکیل درخت کوتاه‌ترین مسیر باشد، الگوریتم می‌بایست دنبالهٔ π
را که π v
پدر رأس v
در درخت کوتاه‌ترین مسیر است، به همراه دنبالهٔ d
به‌روز کند.

الگوریتم

در پیاده‌سازی، برای اینکه مشخص کنیم چه رئوسی در مجموعهٔ S

هستند، در هر مرحله رأسِ وارد شده به S
را برچسب می‌زنیم.

پیاده‌سازی

یک پیاده‌سازی نوعی به این شرح است:

 1 Algorithm Dijkstra(G,s)
 2 Input: G=(V,E), s(the source vertex)
 3 Output: two sequence d and 
  
    
      
        π
      
    
    
  
4 begin 5 for all vertices w do 6 d w
= ∞
7 π w
= NULL 8 d s
= ۰ 9 while there exists an unmarked vertex do 10 let w be an unmarked vertex such that d w
is minimum 11 mark w 12 for all edge (w,z) such that z is unmarked do 13 if d w + w e i g h t ( w , z ) < d z
then 14 d z
= d w + w e i g h t ( w , z )
15 π z
= w 16 end

پیچیدگی زمانی

در ساده‌ترین پیاده‌سازی الگوریتمِ دایکسترا، داده‌ها در آرایه یا لیست پیوندی ذخیره می‌شوند که بدین ترتیب مینیمم مقدار d

برای رئوس خارج S
با الگوریتمی خطی یافت می‌شود. در این حالت پیچیدگی زمانی O ( | V | 2 + | E | )
خواهد بود، چراکه در گراف بدون جهت هر یال دقیقاً دو بار و در گراف جهت‌دار هر یال دقیقاً یک بار پیمایش می‌شود و هم‌چنین پیدا کردن مینیمم، ( | O ( | V
زمان می‌خواهد که این مینیمم پیدا کردن | V |
بار تکرار خواهد شد.

الگوریتم دایکسترا با نگهداری گراف در فهرست مجاورت و استفاده از هرم دودویی یا درخت جستجوی دودویی خود-متوازن (برای پیدا کردن مینیمم) با پیچیدگی زمانی O ( ( | V | + | E | ) l o g | V | )

پیاده‌سازی می‌شود. در صورت استفاده از هیپ فیبوناتچی به جای صف اولویت‌دار، پیچیدگی زمانی با آنالیز استهلاکی (Amortized analysis) به O ( | E | + | V | l o g | V | )
بهبود می‌یابد.

کاربردها

از جمله مهم‌ترین کاربردهای این روش می‌توان به محاسبهٔ کوتاه‌ترین فاصلهٔ دو نقطه در یک شهر از طریق راه‌های زمینی اشاره نمود. برای محاسبهٔ کوتاه‌ترین مسیر بین دو نقطه باید نقاط مورد نظر در یک نقشه را علامت‌گذاری کرد و با استفاده از مشخصات نقاط (طول، عرض و ارتفاع) فاصلهٔ دو نقطه را در هر بار عملیات محاسبه نمود. توجه داریم که در ترافیک سرعت خودروها به شدت پایین آمده و این امر می‌تواند در انتخاب کوتاه‌ترین مسیر تأثیرگذار باشد چرا که ممکن است بین دو نقطه a,b راه‌های ۱و۲ موجود باشد که راه ۱ اتوبان و از خارج شهر و راه ۲ از داخل شهر عبور می‌کند. فرض کنید فاصلهٔ a,b از طریق راه ۱ حدود ۱۰ کیلومتر و از طریق راه ۲ حدود ۷ کیلومتر باشد ولی راه ۲ علی رقم فاصلهٔ کمتر دارای ترافیک سنگین است در نتیجه می‌توان انتظار داشت که در ساعات شلوغی استفاده از راه ۱ بهتر باشد. از آن جا که اساس محاسبات در این روش بر پایهٔ فاصله بین دو نقطه است می‌توان کاهش سرعت را با افزایش فواصل هم ارز نمود چرا که اگر رابطهٔ سرعت و فاصله را خطی در نظر بگیریم (D=V.T)تاثیر کاهش سرعت و افزایش مسافت یکسان است. از این رو لازم است تا ضرایب تعدیلی در فواصل بین نقاط ضرب شده و این مسائل را در محاسبات لحاظ کرد. از جمله مهم‌ترین این ضرایب می‌توان به ۳ مورد زیر اشاره نمود: ۱-ضریب ترافیک و شلوغی ۲-ضریب عرض معبر ۳-ضریب شیب که نشانگر افت سرعت در سر بالایی هااست. گرچه تعیین این ضرایب برای نقاط مختلف شهر نیازمند کارشناسان متخصص ترافیک و بررسی‌های آماری دقیق می‌باشد ولی می‌توان انتظار داشت که در اکثر موارد این ضرایب بین مقادیر ۱ تا ۲ بسته به شرایط تغییر کنند.

  • مسیریابی (Routing)

منابع

  • Thomas H. Cormen, Charles E. Leiserson, Ronald L. Rivest, and Clifford Stein. Introduction to Algorithms, Second Edition. MIT Press and McGraw-Hill, ۲۰۰۱. ISBN 0-262-03293-7.
  • Udi Manber. Introduction to Algorithms — A Creative Approach. MIT Press and Addison-Wesley, ۱۹۸۹. ISBN 0-201-12037-2.
  • Donald E. Knuth. The Art Of Computer Programming Vol ۱., Third Edition. Addison-Wesley, ۱۹۹۷. ISBN 0-201-89683-4.
  • Douglas B. West. Introduction to Graph Theory, Second Edition. Prentice Hall, ۲۰۰۱. ISBN 0-13-014400-2.

پیوند به بیرون

  • آموزش الگوریتم دکسترا برای مسابقات برنامه نویسی
  • C/C++
    • Dijkstra's Algorithm in C Programming Language
    • Dijkstra's Algorithm in C++
    • Implementation in Boost C++ library
  • Java
    • Applet by Carla Laffra of Pace University
    • A Java library for path finding with Dijkstra's Algorithm and example Applet
    • Dijkstra's Algorithm Applet
    • Dijkstra's algorithm as bidirectional version in Java
    • Hipster: An Open-Source Java Library for Heuristic Search with Dijkstra's algorithm and examples
    • Open Source Java Graph package with implementation of Dijkstra's Algorithm
    • Shortest Path Problem: Dijkstra's Algorithm
    • Visualization of Dijkstra's Algorithm
  • C#/.Net
    • Dijkstra's Algorithm in C# بایگانی‌شده در ۲ دسامبر ۲۰۰۸ توسط Wayback Machine
    • Fast Priority Queue Implementation of Dijkstra's Algorithm in C# بایگانی‌شده در ۲۹ دسامبر ۲۰۱۱ توسط Wayback Machine
    • QuickGraph, Graph Data Structures and Algorithms for .NET بایگانی‌شده در ۲۱ ژانویه ۲۰۱۸ توسط Wayback Machine
  • Dijkstra's Algorithm Simulation
  • Oral history interview with Edsger W. Dijkstra, Charles Babbage Institute University of Minnesota, Minneapolis.
  • Animation of Dijkstra's algorithm
  • Implementation in T-SQL
  • A MATLAB program for Dijkstra's algorithm بایگانی‌شده در ۱۸ دسامبر ۲۰۱۲ توسط Wayback Machine
  • Step through Dijkstra's Algorithm in an online JavaScript Debugger
آخرین نظرات
کلیه حقوق این تارنما متعلق به فرا دانشنامه ویکی بین است.