ഹീപ് ഉപയോഗിച്ച് സംഖ്യകളയും മറ്റും ക്രമത്തിലാക്കാൻ ഉപയോഗിക്കുന്ന സോർട്ടിങ്ങ് അൽഗൊരിതമാണ്‌ ഹീപ് സോർട്ട്. സെലക്ഷൻ സോർട്ട് കുടുംബത്തില്പ്പെട്ട ഒരു താരതമ്യ സോർട്ട് അൽഗൊരിതമാണ്‌ ഇത്. സാധാരണ രീതിയിൽ ക്വിക്ക് സോർട്ടിനെക്കാൾ മെല്ലെയാണ്‌ ഇതിന്റെ പ്രവർത്തനമെങ്കിലും മോശം സമയസങ്കീർണ്ണത ആണെന്ന മെച്ചമുണ്ട്. ഒരു in-place അൽഗൊരിതമായതിനാൽ അറേയ്ക്കു പുറമെ മെമ്മറി മാത്രമേ ഇതിന്‌ ആവശ്യമുള്ളൂ. ഹീപ് സോർട്ട് ഒരു സ്റ്റേബിൾ സോർട്ട് അല്ല.

ഹീപ് സോർട്ട്
ഹീപ് സോർട്ട് ഉപയോഗിച്ച് ഒരു അറേ സോർട്ട് ചെയ്യുന്നു. ആദ്യം ഹീപ് നിയമം അനുസരിക്കുന്ന രീതിയിൽ അംഗങ്ങളെ ക്രമീകരിക്കുന്നു. സോർട്ടിങ്ങിനു തൊട്ടു മുമ്പുള്ള ഹീപ് ട്രീ കാണിച്ചിരിക്കുന്നു
ഹീപ് സോർട്ട് ഉപയോഗിച്ച് ഒരു അറേ സോർട്ട് ചെയ്യുന്നു. ആദ്യം ഹീപ് നിയമം അനുസരിക്കുന്ന രീതിയിൽ അംഗങ്ങളെ ക്രമീകരിക്കുന്നു. സോർട്ടിങ്ങിനു തൊട്ടു മുമ്പുള്ള ഹീപ് ട്രീ കാണിച്ചിരിക്കുന്നു
ഹീപ് സോർട്ട് ഉപയോഗിച്ച് ഒരു അറേ സോർട്ട് ചെയ്യുന്നു. ആദ്യം ഹീപ് നിയമം അനുസരിക്കുന്ന രീതിയിൽ അംഗങ്ങളെ ക്രമീകരിക്കുന്നു. സോർട്ടിങ്ങിനു തൊട്ടു മുമ്പുള്ള ഹീപ് ട്രീ കാണിച്ചിരിക്കുന്നു.
കുടുംബംസോർട്ടിങ്ങ് അൽഗൊരിതം
ദത്തസങ്കേതംഅറേ
കൂടിയ സമയസങ്കീർണ്ണത
കുറഞ്ഞ സമയസങ്കീർണ്ണത[1]
ശരാശരി സമയസങ്കീർണ്ണത
കൂടിയ സ്ഥലസങ്കീർണ്ണതആകെ , അറേയ്ക്കു പുറമെ
Optimalഅല്ല

അൽഗൊരിതം

തിരുത്തുക

അറേയിലെ സംഖ്യകളെ ഒരു ഹീപ് ആക്കി മാറ്റുകയാണ്‌ അൽഗൊരിതത്തിലെ ആദ്യ പടി. ഇത്   സമയമുപയോഗിച്ച് ചെയ്യാൻ സാധിക്കും. ഇതിനുശേഷം അറേ ഹീപ് നിയമം അനുസരിക്കുമെന്നതിനാൽ ഏറ്റവും വലിയ സംഖ്യ അറേയുടെ ആദ്യത്തിലായിരിക്കും. ഇതിനെ തൽസ്ഥാനത്തുനിന്ന് നീക്കി അറേയുടെ അവസാന സ്ഥാനത്ത് കൊണ്ടിടുന്നു. ഇത്   സമയമെടുക്കുന്നു. ഇങ്ങനെ തുടരുന്നതു വഴി സംഖ്യകളെയെല്ലാം ക്രമത്തിലാക്കാം. ഈ പടി N തവണ ചെയ്യണമെന്നതിനാൽ അൽഗൊരിതത്തിന്റെ ആകെ സമയസങ്കീർണ്ണത   ആണ്‌.

ഏറ്റവും വലിയ സംഖ്യയെ തുടർച്ചയായി കണ്ടുപിടിക്കുന്നതുവഴിയാണ്‌ ഈ അൽഗൊരിതം സോർട്ടിങ്ങ് നടത്തുന്നതെന്നതിനാൽ ഇത് സെലക്ഷൻ സോർട്ട് കുടുംബത്തിൽ പെടുന്നതാണ്‌.

താരതമ്യം

തിരുത്തുക

സാധാരണരീതിയിൽ   സമയമെടുക്കുന്ന മറ്റൊരു താരതമ്യസോർട്ടിങ്ങ് അൽഗൊരിതമായ ക്വിക്ക് സോർട്ട് ഹീപ് സോർട്ടിനെക്കാൾ വേഗതയേറിയതാണ്‌. എങ്കിലും ക്വിക്ക് സോർട്ടിന്റെ മോശം സമയസങ്കീർണ്ണത   ആയതിനാൽ ചില വലിയ അറേകൾ ക്രമത്തിലാക്കാൻ വളരെയധികം സമയമെടുക്കുന്ന ക്വിക്ക് സോർട്ട് പ്രാവർത്തികമല്ല. ക്വിക്ക് സോർട്ട് അൽഗൊരിതം അറിയുന്ന വ്യക്തിക്ക് അതിനെക്കൊണ്ട് വളരെയധികം സമയമെടുപ്പിക്കാനാകുമെന്നതിനാൽ സുരക്ഷാപ്രശ്നങ്ങളുമുണ്ടാകാൻ സാദ്യതയുണ്ട്. അതിനാൽ ചില റിയൽ-ടൈം അൽഗൊരിതങ്ങളും സുരക്ഷ ആവശ്യമുള്ള അൽഗൊരിതങ്ങളും ക്വിക്ക് സോർട്ടിനെക്കാൾ ഹീപ് സോർട്ടിന്‌ മുൻഗണന നൽകുന്നു.

മെർജ് സോർട്ടും സാധാരണരീതിയിൽ   സമയമെടുക്കുന്നു. എങ്കിലും ലിസ്റ്റിനു പുറമെ   മെമ്മറി മെർജ് സോർട്ടിന്‌ ആവശ്യമുണ്ട്. എങ്കിലും ചില കാര്യങ്ങളിൽ മെർജ് സോർട്ട് ഹീപ് സോർട്ടിനെക്കാൾ മികച്ചുനിൽക്കുന്നു:

  • മെർജ് സോർട്ട് ഒരു സ്റ്റേബിൾ സോർട്ട് ആണ്‌
  • സാധാരണ കം‌പ്യൂട്ടറുകളിലെ അറേകളിൽ മെർജ് സോർട്ട് ഹീപ് സോർട്ടിനെക്കാൾ വേഗത്തിൽ സോർട്ടിങ്ങ് നടത്തുന്നു
  • ഒന്നിലധികം പ്രോസസ്സറുകൾ സമാന്തരമായി ഉപയോഗിക്കുന്നതു വഴി മെർജ് സോർട്ടിന്റെ വേഗത വർദ്ധിപ്പിക്കാം. ഹീപ് സോർട്ട് ഇങ്ങനെ വേഗത്തിലാക്കാൻ സാധിക്കില്ല
  • ലിങ്ക്ഡ് ലിസ്റ്റുകളിൽ മെർജ് സോർട്ട് ചെയ്യാൻ സാധിക്കും. എന്നാൽ ഹീപ് സോർട്ട് ചെയ്യാൻ സാധിക്കില്ല

ഇതും കൂടി കാണുക

തിരുത്തുക
  1. http://dx.doi.org/10.1006/jagm.1993.1031
"https://ml.wikipedia.org/w/index.php?title=ഹീപ്_സോർട്ട്&oldid=1810756" എന്ന താളിൽനിന്ന് ശേഖരിച്ചത്