مرتب‌سازی به روش درجی

کارت‌های مرا مرتب کن

الگوریتم مرتب‌سازی به روش درجی (Insertion sort) یکی از الگوریتم‌های رایج است ولی چندان پرکاربرد نیست، البته نسبت به بعضی از الگوریتم‌ها مرتب‌سازی بهینه‌تر است. این الگوریتم در داده‌های کوچک بسیار مناسب است و در روش مرتب‌سازی سریع نیز از این الگوریتم استفاده شده است. مرتب‌سازی در این الگوریتم مثل کاری است که ما خودمان بصورت دستی برای مرتب کردن داده‌هایمان انجام می‌دهیم.
کد خبر: ۳۷۱۶۳۸

اما این الگوریتم چگونه کار می‌کند. فرض کنید داده‌های ما بصورت زیر تعریف شده‌اند.

A1, A2, A3, … , An

ابتدا عنصر A1 و A2 را انتخاب می‌کنیم سپس این دو عنصر را با هم مقایسه می‌کنیم و در جای مناسب نسبت به هم قرار می‌دهیم به طوری که مجموعه حاصل از انتخاب عناصر A1 و A2 مرتب باشد. سپس در مرحله بعد عنصر A3 را انتخاب می‌کنیم و آن را با A1 و A2 مقایسه می‌کنیم و در جای مناسب خود قرار می‌دهیم به طوری که مجموعه حاصل مرتب باشد. این عمل را آنقدر ادامه می‌دهیم تا به عنصر nام برسیم.

بگذارید الگوریتم بالا را با یک مثال عددی بیشتر بررسی بکنیم، داریم:

12,1,15,23

در مرحله اول 12 و 1 را انتخاب می‌کنیم سپس آنها را نسبت به هم در جای مناسبی قرار می‌دهیم تا مجموعه حاصل مرتب باشد که حاصل بصورت زیر می‌شود:

1,12

سپس عدد 15 را انتخاب می‌کنیم و آن را طوری در مجموعه قبلی قرار می‌دهیم که ترتیب عناصر به‌هم نخورد، یعنی عنصر 15 را در جای مناسب خود نسبت به اعد اد 12 و 1 قرار می‌دهیم که خروجی این مرحله بصورت زیر می‌شود:

1,12,15

در مرحله بعدی که عدد 23 را انتخاب می‌کنیم خروجی به صورت زیر می‌شود:

1,12,15,23

2 نکته در مورد این الگوریتم حائز اهمیت هست؛

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

دوم این که همان طور که در مثال بالا مشاهده می‌کنید، هر مرحله که این الگوریتم جلو می‌رود مجموعه حاصل مرتب شده است و این خودش یکی از مزیت‌های این الگوریتم است.

شبه کد این الگوریتم به زبان ++C بصورت زیر است:

void InsertSort(int a[]،int n){

int i،j،temp;

for(i=1;i«n;++i){

temp = a[i];

j = i - 1;

while(j»=0 && temp« a[j]){

a[j+1] = a[j];

--j; }

a[j+1] = temp; }

}

محاسبه پیچیدگی زمانی الگوریتم

در این الگوریتم نیز مانند باقی الگوریتم‌ها عمل غالب عمل مقایسه است. اما برای این الگوریتم ما 2حالت در نظر می‌گیریم یکی شرایط بد یکی در شرایط میانگین، معمولا برای مقایسه پیچیدگی زمانی چند الگوریتم شرایط میانگین را ملاک قرار می‌دهند.

بدترین شرایط

در این شرایط آرایه بصورت نزولی مرتب شده است و قرار است که با مرتب‌سازی درجی آن را به صورت صعودی مرتب کنیم. در این شرایط هر بار که حلقه بیرونی برای انتخاب عنصر بعدی یا همان عنصر iم اجرا می‌شود. این عنصر از تمامی‌عناصر موجود در مجموعه بدست آمده در آن مرحله که i-1 عضو دارد کوچک‌تر است، بنابراین تعداد مقایسه‌ها در حلقه درونی until ـ repeat برابر i-1 است. با توجه به مطالب گفته شده تعداد کل مقایسه‌ها در زمان اجرای حلقه بیرونی for از فرمول زیر به دست می‌آید.

Zigma i=2 to n (i-1) = n(n-1)/2

حالت میانگین

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

محل تعداد مقایسه

i 1

i-1 2

i-2 3

...

2 i-1

1 i-1

اگر عنصر iم در محل اول آرایه یعنی 1 قرار بگیرد تعداد مقایسه برابر i-1است، بخاطر این‌که در حلقه درونی مقدار j برابر صفر می‌گردد و شرط اول حلقه while اشتباه می‌شود و شرط دوم دیگر محاسبه نمی‌شود. با این استدلال برای مقدار مشخص i میانگین تعداد مقایسه‌ای که برای درج عنصر i باید انجام شود از روش زیر محاسبه می‌شود.

1(1/i)+2(2/i)+…( i-1)(1/i)+(i-1)(1/i)

= 1/I Zigma k

= 1 to I -1 (k+( i-1)/i)

= (i-1)(i)/2i + (i-1)/i

=( i+1)/2 – 1/i

پس میانگین تعداد مقایسه برای مرتب کردن آرایه مورد نظر در روش مرتب‌سازی درجی به صورت زیر محاسبه می‌شود:

Zigma I = 2 to n (( i+1)/2 – 1/i)

=(n+4)(n-1)/4–Zigma i=2 to n (1/i)

محاسبه سری با جمله عمومی1/i برابر Ln است(در ریاضی اثبات شده است)، پس عبارت درجه بیشتر در بالا مقدار:

(n+4)(n-1)/4

همان‌طور که مشخص است حد بی نهایت عبارت بالا برابر n به توان 2 تقسیم بر 4 است، پس می‌توان گفت این الگوریتم از مرتبه n2 است.

اگر نتایج بدترین حالت و حالت میانگین را با هم مقایسه کنیم می‌بینیم که تعداد مقایسه‌‌ها در حالت میانگین نصف بدترین حالت است.

امیر بهاالدین سبط الشیخ

newsQrCode
ارسال نظرات در انتظار بررسی: ۰ انتشار یافته: ۰

نیازمندی ها