"സ്കിപ്‌ ലിസ്റ്റ്" എന്ന താളിന്റെ പതിപ്പുകൾ തമ്മിലുള്ള വ്യത്യാസം

വിക്കിപീഡിയ, ഒരു സ്വതന്ത്ര വിജ്ഞാനകോശം.
Content deleted Content added
വരി 10: വരി 10:
തിരച്ചിൽ തുടങ്ങുമ്പോൾ ആദ്യം ചെയ്യുന്നത് തിരച്ചിൽ തുടങ്ങുന്ന അങ്ങത്തിന്റെ ഏറ്റവും ഉയർന്ന ശ്രേണിയിലെ അടുത്ത അംഗത്തെ നോക്കിയാണ്. തിരയേണ്ട മൂല്യം ആ അംഗത്തെക്കാൾ കൂടുതലാണെങ്കിൽ തിരച്ചിൽ ലിസ്റ്റിന്റെ ആ അംഗത്തിന് ശേഷമുള്ള ഭാഗത്തേക്ക് (അതായത് വലത്തേക്ക്) ചുരുക്കാം. മൂല്യം കുറവ് ആണെങ്കിൽ ഇടത്തേക്കും. ഈ അവസ്ഥയിൽ നമ്മൾ തൊട്ടു താഴെ നിലകളിൽ പോയി ഇതേ ക്രിയകൾ ആവർത്തിക്കും. ഉദാഹരണത്തിന് ഉകളിൽ കൊടുത്ത പ്രമാണപ്രകാരമുള്ള ലിസ്റ്റിൽ 5 എന്ന മൂല്യം തിരയുമ്പോൾ.
തിരച്ചിൽ തുടങ്ങുമ്പോൾ ആദ്യം ചെയ്യുന്നത് തിരച്ചിൽ തുടങ്ങുന്ന അങ്ങത്തിന്റെ ഏറ്റവും ഉയർന്ന ശ്രേണിയിലെ അടുത്ത അംഗത്തെ നോക്കിയാണ്. തിരയേണ്ട മൂല്യം ആ അംഗത്തെക്കാൾ കൂടുതലാണെങ്കിൽ തിരച്ചിൽ ലിസ്റ്റിന്റെ ആ അംഗത്തിന് ശേഷമുള്ള ഭാഗത്തേക്ക് (അതായത് വലത്തേക്ക്) ചുരുക്കാം. മൂല്യം കുറവ് ആണെങ്കിൽ ഇടത്തേക്കും. ഈ അവസ്ഥയിൽ നമ്മൾ തൊട്ടു താഴെ നിലകളിൽ പോയി ഇതേ ക്രിയകൾ ആവർത്തിക്കും. ഉദാഹരണത്തിന് ഉകളിൽ കൊടുത്ത പ്രമാണപ്രകാരമുള്ള ലിസ്റ്റിൽ 5 എന്ന മൂല്യം തിരയുമ്പോൾ.


# '''1''' അഞ്ചിനെക്കാൾ ചെറുത്. ഏറ്റവും മുകളിലെ ശ്രേണിയിൽ അടുത്തത് '''4'''.
# ആദ്യ അംഗത്തിന്റെ മൂല്യം '''1''' അഞ്ചിനെക്കാൾ ചെറുത്. ഏറ്റവും മുകളിലെ ശ്രേണിയിൽ അടുത്തത് '''4'''.
# '''4''' അഞ്ചിനെക്കാൾ ചെറുത്. മുകളിലെ ശ്രേണിയിൽ അടുത്തത് '''6'''. അഞ്ചിനെക്കാൾ വലുതായതിനാൽ അടുത്ത ശ്രേണിയിൽ പോകുന്നു.
# അംഗത്തിന്റെ '''4''' അഞ്ചിനെക്കാൾ ചെറുത്. മുകളിലെ ശ്രേണിയിൽ അടുത്തത് '''6'''. അഞ്ചിനെക്കാൾ വലുതായതിനാൽ അടുത്ത ശ്രേണിയിൽ പോകുന്നു.
# വീണ്ടും '''6'''. അഞ്ചിനെക്കാൾ വലുതായതിനാൽ അടുത്ത ശ്രേണിയിൽ പോകുന്നു.
# വീണ്ടും '''6'''. അഞ്ചിനെക്കാൾ വലുതായതിനാൽ അടുത്ത ശ്രേണിയിൽ പോകുന്നു.
# അഞ്ചിലേക്കെത്തുന്നു.
# അഞ്ചിലേക്കെത്തുന്നു.

12:19, 10 മേയ് 2013-നു നിലവിലുണ്ടായിരുന്ന രൂപം


എളുപ്പത്തിൽ തിരച്ചിൽ നടത്താൻ സഹായിക്കുന്ന വിധം ക്രമീകരിക്കപ്പെട്ടതും ക്രമത്തിലാക്കിയ അംഗങ്ങളോട് കൂടിയതുമായ ഒരു ലിസ്റ്റ് ഡാറ്റാ സ്ട്രക്‌ച്ചർ ആണ് സ്കിപ്‌ ലിസ്റ്റ്. 1990-ൽ സാക്ഷാൽക്കരിക്കപ്പെട്ട ഈ ഡാറ്റാ സ്ട്രക്‌ച്ചർ താരതമ്യേന പുതുതാണ്. പ്രധാനമായും ഇതിന്റെ സ്വീകാര്യത എളുപ്പത്തിൽ തിരച്ചിൽ നടത്തുന്നതിനോടൊപ്പം ഓരോ അംഗങ്ങളെയും ക്രമപ്രകാരം പ്രക്രിയകൾക്ക് വിധേയമാക്കാനും സഹായിക്കുന്നു എന്നതാണ്. ഒരു മാതൃകാപരമായ സ്കിപ്‌ ലിസ്റ്റ് ബൈനറി സെർച്ച്‌ ട്രീകളുടെ അത്ര (അതായത് ലോഗരിതം നിരക്കിൽ) കാര്യക്ഷമമാണ്[1].

ആന്തരിക ഘടന

സ്കിപ്‌ ലിസ്റ്റിന്റെ ഘടന

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

തിരച്ചിൽ

തിരച്ചിൽ തുടങ്ങുമ്പോൾ ആദ്യം ചെയ്യുന്നത് തിരച്ചിൽ തുടങ്ങുന്ന അങ്ങത്തിന്റെ ഏറ്റവും ഉയർന്ന ശ്രേണിയിലെ അടുത്ത അംഗത്തെ നോക്കിയാണ്. തിരയേണ്ട മൂല്യം ആ അംഗത്തെക്കാൾ കൂടുതലാണെങ്കിൽ തിരച്ചിൽ ലിസ്റ്റിന്റെ ആ അംഗത്തിന് ശേഷമുള്ള ഭാഗത്തേക്ക് (അതായത് വലത്തേക്ക്) ചുരുക്കാം. മൂല്യം കുറവ് ആണെങ്കിൽ ഇടത്തേക്കും. ഈ അവസ്ഥയിൽ നമ്മൾ തൊട്ടു താഴെ നിലകളിൽ പോയി ഇതേ ക്രിയകൾ ആവർത്തിക്കും. ഉദാഹരണത്തിന് ഉകളിൽ കൊടുത്ത പ്രമാണപ്രകാരമുള്ള ലിസ്റ്റിൽ 5 എന്ന മൂല്യം തിരയുമ്പോൾ.

  1. ആദ്യ അംഗത്തിന്റെ മൂല്യം 1 അഞ്ചിനെക്കാൾ ചെറുത്. ഏറ്റവും മുകളിലെ ശ്രേണിയിൽ അടുത്തത് 4.
  2. അംഗത്തിന്റെ 4 അഞ്ചിനെക്കാൾ ചെറുത്. മുകളിലെ ശ്രേണിയിൽ അടുത്തത് 6. അഞ്ചിനെക്കാൾ വലുതായതിനാൽ അടുത്ത ശ്രേണിയിൽ പോകുന്നു.
  3. വീണ്ടും 6. അഞ്ചിനെക്കാൾ വലുതായതിനാൽ അടുത്ത ശ്രേണിയിൽ പോകുന്നു.
  4. അഞ്ചിലേക്കെത്തുന്നു.

അവലംബം

  1. "Skip Lists: A Linked List with Self-Balancing BST-Like Properties". MSDN. Archived from the original on 10 മെയ്‌ 2013. Retrieved 10 മെയ്‌ 2013. {{cite web}}: Check date values in: |accessdate= and |archivedate= (help)
"https://ml.wikipedia.org/w/index.php?title=സ്കിപ്‌_ലിസ്റ്റ്&oldid=1748705" എന്ന താളിൽനിന്ന് ശേഖരിച്ചത്