ebooksgratis.com

See also ebooksgratis.com: no banners, no cookies, totally FREE.

CLASSICISTRANIERI HOME PAGE - YOUTUBE CHANNEL
Privacy Policy Cookie Policy Terms and Conditions
מיון ערימה – ויקיפדיה

מיון ערימה

מתוך ויקיפדיה, האנציקלופדיה החופשית

מיון ערימהאנגלית: Heapsort) הוא אלגוריתם למיון המבוסס על מבנה הנתונים ערימה (Heap). מיון ערימה הוא סוג של מיון בחירה, ובדומה לו מבצע את פעולתו במקום, תוך שימוש בכמות קטנה וקבועה של שטח אחסון. על חומרת מחשב מקובלת, יישום של מיון ערימה הוא איטי במקצת מיישום של מיון מהיר, אך פועל בזמן של O\left(n\log n\right) גם במקרה הגרוע.

[עריכה] תיאור האלגוריתם

התיאור הבא מתייחס ל"ערימת מקסימום", שבה כל הורה גדול בערכו משני בניו.

  1. בונים ערימה ממערך של איברים למיון.
  2. מוציאים מהערימה את השורש (המהווה את הערך המקסימלי), ומכניסים אותו למיקום הפנוי הגדול ביותר במערך. מתקבל מבנה של 'כמעט ערימה' הקטן בגודלו באיבר אחד.
  3. מוציאים את האיבר האחרון במבנה (שהיה אחד הערכים הקטנים בערימה) ומציבים אותו במקום השורש שהוצא.
  4. מבצעים פעולת Heapify שמטרתה לתקן את המבנה ולהפוך אותו שוב לערימה חוקית. מבצעים זאת באמצעות פעולה מחזורית מהשורש ומטה.
  5. חוזרים שוב על תהליך הוצאת השורש עד אשר הערימה מגיעה לגודל של איבר בודד והמערך מכיל את כל איברי הערימה ממויינים.

[עריכה] פסאודו קוד

פונקציות עזר:


 Build-Heap(A)
 heap_size[A] <- length[A]
 for i <- length[A]/2 Downto 1
   do Heapify(A,i)


 Heapify(A,i)
 l <- LEFT(i)     //the left son of vertex i     // i הבן השמאלי של צומת
 r <- RIGHT(i)    //the right son of vertex i    // i הבן הימני של צומת
 if l <= heapsize[A] and A[l] > A[i]
   then largest <- l
   else largest <- i
 if r<=heapsize[A] and A[r] > A[largest]
   then largest <- r
 if largest != i
   then exchange A[i] <-> A[largest]
 Heapify(a,largest)

הפונקציה העיקרית:


 HeapSort(A)
 Build-Heap(A)
 for i <- length[A] downto 2
   do exchange A[1] <-> A[i]
     heap-size[A] <- heap-size[A]-1
     Heapify(A,i)


aa - ab - af - ak - als - am - an - ang - ar - arc - as - ast - av - ay - az - ba - bar - bat_smg - bcl - be - be_x_old - bg - bh - bi - bm - bn - bo - bpy - br - bs - bug - bxr - ca - cbk_zam - cdo - ce - ceb - ch - cho - chr - chy - co - cr - crh - cs - csb - cu - cv - cy - da - de - diq - dsb - dv - dz - ee - el - eml - en - eo - es - et - eu - ext - fa - ff - fi - fiu_vro - fj - fo - fr - frp - fur - fy - ga - gan - gd - gl - glk - gn - got - gu - gv - ha - hak - haw - he - hi - hif - ho - hr - hsb - ht - hu - hy - hz - ia - id - ie - ig - ii - ik - ilo - io - is - it - iu - ja - jbo - jv - ka - kaa - kab - kg - ki - kj - kk - kl - km - kn - ko - kr - ks - ksh - ku - kv - kw - ky - la - lad - lb - lbe - lg - li - lij - lmo - ln - lo - lt - lv - map_bms - mdf - mg - mh - mi - mk - ml - mn - mo - mr - mt - mus - my - myv - mzn - na - nah - nap - nds - nds_nl - ne - new - ng - nl - nn - no - nov - nrm - nv - ny - oc - om - or - os - pa - pag - pam - pap - pdc - pi - pih - pl - pms - ps - pt - qu - quality - rm - rmy - rn - ro - roa_rup - roa_tara - ru - rw - sa - sah - sc - scn - sco - sd - se - sg - sh - si - simple - sk - sl - sm - sn - so - sr - srn - ss - st - stq - su - sv - sw - szl - ta - te - tet - tg - th - ti - tk - tl - tlh - tn - to - tpi - tr - ts - tt - tum - tw - ty - udm - ug - uk - ur - uz - ve - vec - vi - vls - vo - wa - war - wo - wuu - xal - xh - yi - yo - za - zea - zh - zh_classical - zh_min_nan - zh_yue - zu -