I datalogi er en liste ( engelsk liste ) en abstrakt datatype , som er et ordnet sæt værdier , hvor en bestemt værdi kan forekomme mere end én gang. Et eksempel på en liste er en computerimplementering af det matematiske koncept for en endelig rækkefølge . Forekomster af værdier i en liste kaldes elementer af listen ( engelsk element, indgang eller element ); hvis værdien forekommer flere gange, betragtes hver forekomst som et separat element.
Udtrykket liste refererer også til flere specifikke datastrukturer , der bruges i implementeringen af abstrakte lister, især linkede lister .
Ved at bruge notationen af C. Hoares syntaktisk orienterede konstruktionsmetode kan definitionen af en liste skrives som følger:
Den første linje i denne definition betyder, at listen over elementer af typen (f.eks. "liste over ") er den diskriminerede forening af den tomme liste og det kartesiske produkt af atomet af typen med listen over . For at oprette lister bruges to konstruktører (den anden linje i definitionen), hvoraf den første opretter en tom liste, og den anden - en ikke-tom liste. Det er helt klart, at den anden konstruktør modtager et atom og en liste som parametre som input, og returnerer en liste, hvis første element er det oprindelige atom, og resten er elementerne i den originale liste. Det vil sige, at atomet er foranstillet til listen, hvilket er årsagen til et sådant navn for konstruktøren. Den tomme liste er ikke et atom og kan derfor ikke sættes foran. På den anden side er en tom liste nul-elementet til at konstruere lister, så enhver liste indeholder en tom liste til allersidst - konstruktionen begynder med den.
Den tredje linje definerer vælgerne for listen, det vil sige operationerne for at få adgang til elementerne på listen. Vælgeren tager en liste som input og returnerer det første element i denne liste, dvs. resultatets type er type . Denne vælger kan ikke modtage en tom liste som input - i dette tilfælde er resultatet af operationen udefineret. Vælgeren returnerer listen opnået fra input som et resultat af at skære hovedet af (det første element). Denne vælger kan heller ikke acceptere en tom liste som input, da resultatet af operationen i dette tilfælde er udefineret. Ved at bruge disse to operationer kan du få et hvilket som helst element fra listen. For at få det tredje element på listen (hvis der er et), skal du f.eks. anvende vælgeren to gange efter hinanden og derefter anvende vælgeren . Med andre ord, for at få det element på listen, der er på plads (startende med for det første element, som det er sædvanligt i programmering), skal du anvende vælgeren én gang og derefter anvende vælgeren .
Den fjerde linje i definitionen beskriver listeprædikater , det vil sige funktioner, der returnerer en boolesk værdi afhængigt af nogle betingelser. Det første prædikat returnerer en værdi, hvis den givne liste er tom. Det andet prædikat virker omvendt. Til sidst beskriver den femte linje de dele af listen, der som allerede nævnt er de tomme og ikke-tomme lister.
Datastrukturen defineret på denne måde har nogle egenskaber:
Lister bruges til at gemme sæt af elementer af samme type. Sådanne elementer kan sorteres til brug i søgefunktioner eller funktioner til hurtigt at indsætte nye elementer i en liste.
Lister i funktionelle sprog er en grundlæggende struktur. De fleste funktionelle sprog har indbyggede faciliteter til at arbejde med lister, såsom at få listens længde, hovedet (det første element på listen), halen (den del af listen, der følger efter det første element), at anvende en funktion på hvert element i listen ( Map ), folde listen osv.
Haskell sprog The Lisp LanguageDatatyper | |
---|---|
Ufortolkelig | |
Numerisk | |
Tekst | |
Reference | |
Sammensatte | |
abstrakt | |
Andet | |
relaterede emner |
Datastrukturer | |
---|---|
Lister | |
Træer | |
Tæller | |
Andet |