Sha256: 364b874c8529d0aefbe0e8cfdf983bbda4811dd891333be2e1f3c9599c957578

Contents?: true

Size: 673 Bytes

Versions: 463

Compression:

Stored size: 673 Bytes

Contents

module SimpleLinkedList

type LinkedList<'a> = 
    | Nil 
    | Element of datum:'a * next:LinkedList<'a>

let nil = Nil

let create x n = Element (x, n)

let isNil x = 
    match x with
    | Nil -> true
    | _   -> false

let next x = 
    match x with
    | Nil -> Nil
    | Element (_, n) -> n

let datum x = 
    match x with
    | Nil -> failwith "The nil list has no datum."
    | Element (y, _) -> y

let toList x = 
    let rec loop acc item = 
        match item with
        | Nil -> acc |> List.rev
        | Element (b, n) -> loop (b :: acc) n

    loop [] x

let fromList xs = List.foldBack create xs Nil

let reverse x = x |> toList |> List.rev |> fromList

Version data entries

463 entries across 396 versions & 1 rubygems

Version Path
trackler-2.0.6.27 tracks/fsharp/exercises/simple-linked-list/Example.fs
trackler-2.0.6.26 tracks/fsharp/exercises/simple-linked-list/Example.fs
trackler-2.0.6.25 tracks/fsharp/exercises/simple-linked-list/Example.fs
trackler-2.0.6.24 tracks/fsharp/exercises/simple-linked-list/Example.fs
trackler-2.0.6.23 tracks/fsharp/exercises/simple-linked-list/Example.fs
trackler-2.0.6.22 tracks/fsharp/exercises/simple-linked-list/Example.fs
trackler-2.0.6.21 tracks/fsharp/exercises/simple-linked-list/Example.fs
trackler-2.0.6.20 tracks/fsharp/exercises/simple-linked-list/Example.fs
trackler-2.0.6.19 tracks/fsharp/exercises/simple-linked-list/Example.fs
trackler-2.0.6.18 tracks/fsharp/exercises/simple-linked-list/Example.fs
trackler-2.0.6.17 tracks/fsharp/exercises/simple-linked-list/Example.fs
trackler-2.0.6.16 tracks/fsharp/exercises/simple-linked-list/Example.fs
trackler-2.0.6.15 tracks/fsharp/exercises/simple-linked-list/Example.fs
trackler-2.0.6.14 tracks/fsharp/exercises/simple-linked-list/Example.fs
trackler-2.0.6.13 tracks/fsharp/exercises/simple-linked-list/Example.fs
trackler-2.0.6.12 tracks/fsharp/exercises/simple-linked-list/Example.fs
trackler-2.0.6.11 tracks/fsharp/exercises/simple-linked-list/Example.fs
trackler-2.0.6.10 tracks/fsharp/exercises/simple-linked-list/Example.fs
trackler-2.0.6.9 tracks/fsharp/exercises/simple-linked-list/Example.fs
trackler-2.0.6.8 tracks/fsharp/exercises/simple-linked-list/Example.fs