مرتب سازی ادغامی (Merge Sort) در جاوا

سلام دوستان دراین سری از آموزش برنامه نویسی جاوا به آموزش مرتب سازی ادغامی (Merge Sort) در جاوا می پردازیم از شاید بپرسید مرتب سازی ادغامی (Merge Sort) چیست ؟ در ادامه این سوال را نیز پاسخ خواهیم داد و الگوریتم مربوط به مرتب سازی ادغامی (Merge Sort) را نیز بررسی می کنیم با ما همراه باشید.
 

الگوریتم مرتب سازی ادغامی (Merge Sort)

  1. اگر طول لیست ۰ یا ۱ باشد آن پیش از این مرتب شده‌است در غیر این صورت
  2. لیست نامرتب را به دو زیرلیست که اندازهٔ آن‌ها در حدود نصف سایز لیست اولیه‌است تقسیم می‌کند.
  3. هر زیرلیست را به‌طور بازگشتی با صدا کردن merge sort مرتب می‌کند.
  4. دو تا دوتا زیر لیست‌ها را از آخر ادغام می‌کند تا به یک لیست برسد.

مرتب‌سازی ادغام دو تا ایدهٔ اصلی را با هم ترکیب می‌کند تا زمان اجرایش تقویت شود.

  1. یک لیست کوچک از گام‌های کم‌تری برای مرتب‌کردن نسبت به یک لیست بزرگ استفاده می‌کند.
  2. یرای مرتب کردن دو لیست مرتب‌شده نسبت به دو لیست نامرتب گام‌های کمتری نیاز می‌باشد به عنوان مثال اگر این لیست‌ها مرتب باشند شما مجبور هستید تا هر لیست را فقط یکبار پیمایش کنید.

نحوه کار کرد این الگوریتم را در شکل زیر می توانید مشاهده کنید.
 

 
در ادامه مثالی از Merge Sort را برای شما قرار می دهیم.
برای اینکار سه متد نوشته شده است که در ادامه مشاهده می کنید.

در بالا اگر از پایین در نظر بگیریم ابتدا باید خانه کمترین وسطی و بیشترین را پیدا می کنیم این کار توسط متد mergeParts انجام می شود بعد از اینکار doMergeSort انجام می شود که در داخل آن mergeParts صدا زده شده است و در نهایت یک متد نهایی وجود دارد که نام آن sort است کافی است یک آرایه به این متد ارسال شود سپس براساس مرتب سازی ادغامی (Merge Sort) مرتب می شود.
در نهایت برای اینکه عمل Sort را انجام دهیم از متد زیر استفاده می کنیم.

و در نهایت خروجی کد زیر همانند زیر می شود.

 
این آموزش هم به پایان رسید.
موفق و پیروز باشید.

مطالعه بیشتر