Seznam asociací - Association list

Seznam asociací
Typasociativní pole
Časová složitost v velká O notace
AlgoritmusPrůměrnýNejhorší případ
ProstorÓ(n)Ó(n)
VyhledáváníÓ(n)Ó(n)
VložitO (1)O (1)
VymazatÓ(n)Ó(n)

v programování a zejména v Lisp, an seznam sdružení, často označované jako seznam, je spojový seznam ve kterém každý prvek seznamu (nebo uzel ) zahrnuje a klíč a hodnota. Seznam asociací se říká spolupracovník hodnotu s klíčem. Aby bylo možné najít hodnotu spojenou s daným klíčem, a sekvenční vyhledávání je použito: každý prvek seznamu je postupně prohledáván, počínaje od hlavy, dokud není klíč nalezen. Asociativní seznamy poskytují jednoduchý způsob implementace asociativní pole, ale jsou účinné, pouze když je počet klíčů velmi malý.

Úkon

An asociativní pole je abstraktní datový typ které lze použít k udržení sbírky páry klíč – hodnota a vyhledat hodnotu spojenou s daným klíčem. Seznam přidružení poskytuje jednoduchý způsob implementace tohoto datového typu.

Chcete-li otestovat, zda je klíč spojen s hodnotou v daném seznamu přidružení, prohledejte seznam počínaje jeho prvním uzlem a pokračujte, dokud nebude nalezen uzel obsahující klíč, nebo dokud hledání nedojde na konec seznamu (v takovém případě klíč není k dispozici). Chcete-li přidat nový pár klíč – hodnota do seznamu přidružení, vytvořte nový uzel pro tento pár klíč – hodnota, nastavte odkaz uzlu jako předchozí první prvek seznamu přidružení a nahraďte první prvek seznamu přidružení s novým uzlem.[1] Ačkoli některé implementace seznamů přidružení zakazují mít více uzlů se stejnými klíči, nejsou takové duplicity pro tento vyhledávací algoritmus problematické: duplicitní klíče, které se objeví později v seznamu, jsou ignorovány.[2]

Je také možné odstranit klíč ze seznamu přidružení skenováním seznamu a vyhledáním každého výskytu klíče a rozdělením uzlů obsahujících klíč ze seznamu.[1] Prohledávání by mělo pokračovat až do konce seznamu, i když je klíč nalezen, pro případ, že by stejný klíč mohl být vložen vícekrát.

Výkon

Nevýhodou asociačních seznamů je, že je čas na vyhledávání Ó(n), kde n je délka seznamu.[3] U velkých seznamů to může být mnohem pomalejší než časy, které lze získat reprezentací asociativního pole jako binární vyhledávací strom nebo jako hash tabulka Kromě toho, pokud není seznam pravidelně prořezáván, aby se odstranily prvky s duplicitními klíči, více hodnot přidružených ke stejnému klíči zvětší velikost seznamu, a tím i čas hledání, aniž by poskytoval jakoukoli kompenzační výhodu.

Jednou z výhod asociačních seznamů je, že lze přidat nový prvek v konstantním čase. Navíc, když je počet klíčů velmi malý, může být prohledávání seznamu přidružení efektivnější než prohledávání binárního vyhledávacího stromu nebo hash tabulky z důvodu větší jednoduchosti jejich implementace.[4]

Knihovny aplikací a softwaru

V počátcích vývoje Lispu byly k vyřešení odkazů na použity seznamy asociací volné proměnné v postupech.[5][6] V této aplikaci je vhodné rozšířit seznamy přidružení o další operaci, která obrátí přidání páru klíč – hodnota bez skenování seznamu pro další kopie stejného klíče. Tímto způsobem může seznam přidružení fungovat jako a zásobník, umožňující lokální proměnné dočasně stín další proměnné se stejnými názvy, aniž by došlo ke zničení hodnot těchto dalších proměnných.[7]

Mnoho programovacích jazyků, včetně Lisp,[5]Systém,[8]OCaml,[9] aHaskell[10] mají funkce pro zpracování seznamů přidružení ve svých standardní knihovny.

Viz také

Reference

  1. ^ A b Marriott, Kim; Stuckey, Peter J. (1998). Programování s omezeními: Úvod. MIT Stiskněte. 193–195. ISBN  9780262133418.
  2. ^ Frické, Martin (2012). „2.8.3 Seznamy asociací“. Logika a organizace informací. Springer. str. 44–45. ISBN  9781461430872.
  3. ^ Knuth, Donald. "6.1 Sekvenční vyhledávání". Umění počítačového programování, Sv. 3: Třídění a vyhledávání (2. vyd.). Addison Wesley. 396–405. ISBN  0-201-89685-0.
  4. ^ Janes, Calvin (2011). „Použití seznamů asociací pro asociativní pole“. Příručka pro vývojáře pro sbírky v Microsoft .NET. Pearson Education. str. 191. ISBN  9780735665279.
  5. ^ A b McCarthy, John; Abrahams, Paul W .; Edwards, Daniel J .; Hart, Timothy P .; Levin, Michael I. (1985). Příručka programátora LISP 1.5. MIT Stiskněte. ISBN  0-262-13011-4. Viz zejména str. 12 pro funkce, které prohledávají seznam přidružení a používají jej k nahrazení symbolů v jiném výrazu, a str. 103 pro aplikaci seznamů přidružení při udržování vazeb proměnných.
  6. ^ van de Snepscheut, Jan L. A. (1993). O čem výpočetní technika je. Monografie v informatice. Springer. str. 201. ISBN  9781461227106.
  7. ^ Scott, Michael Lee (2000). „3.3.4 Seznamy asociací a centrální referenční tabulky“. Programovací jazyková pragmatika. Morgan Kaufmann. str. 137. ISBN  9781558604421.
  8. ^ Pearce, Jon (2012). Programování a metaprogramování ve schématu. Vysokoškolské texty v informatice. Springer. str. 214. ISBN  9781461216827.
  9. ^ Minsky, Yaron; Madhavapeddy, Anil; Hickey, Jason (2013). Real World OCaml: Funkční programování pro masy. O'Reilly Media. str. 253. ISBN  9781449324766.
  10. ^ O'Sullivan, Bryan; Goerzen, John; Stewart, Donald Bruce (2008). Real World Haskell: Kód, kterému můžete věřit. O'Reilly Media. str. 299. ISBN  9780596554309.
  11. ^ „10.1. Seznam nemovitostí“. Cs.cmu.edu. Citováno 29. září 2017.