package knights_tour
sectionYPositions = computeSectionYPositions($el), 10)"
x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
>
Solves the 'Knights Tour' and various 'Poyomino' puzzles
Install
dune-project
Dependency
Authors
Maintainers
Sources
knights_tour-0.0.4.tbz
sha256=dbaafd55fab8dd6a693878310c645c402d7c91e05d62819ae7913908ac17cdf1
sha512=e33e38572ba2e42b876915a74f8e9688a84666d61bc94fa2035d16f2fc6d5bf79d6cc5a2ac1a88d1aa28d8878ec035836df2d7919d2fe9dcd133e1259943ecef
doc/src/knights_tour.searchspace/treequence.ml.html
Source file treequence.ml
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100
type 'a t = | Empty | Single of 'a | Append of {sz: int; lt: 'a t; rt: 'a t } let size = function | Empty -> 0 | Single _ -> 1 | Append {sz;_} -> sz let empty = Empty let is_empty t = size t = 0 let singleton x = Single x let append xs ys = match xs, ys with | Empty, ys -> ys | xs, Empty -> xs | _ -> Append{sz=size xs + size ys; lt=xs; rt=ys} let push x xs = append (singleton x) xs let push_end x xs = append xs (singleton x) let rec pop = function | Empty -> None | Single x -> Some (x, Empty) | Append {lt=Empty;rt;_} -> pop rt | Append {lt=Single x; rt; _} -> Some(x,rt) | Append {lt=Append{lt=a;rt=b;_};rt=c; _} -> pop (append a (append b c)) let rec pop_end = function | Empty -> None | Single x -> Some (x, Empty) | Append {lt; rt=Empty; _} -> pop lt | Append {lt; rt=Single x; _} -> Some(x, lt) | Append {lt=a; rt=Append{lt=b; rt=c; _}; _} -> pop_end (append (append a b) c) let rec map f = function | Empty -> Empty | Single x -> Single (f x) | Append {sz; lt; rt} -> Append {sz; lt=map f lt; rt=map f rt} let rec to_string str = function | Empty -> "nil" | Single x -> str x | Append{lt;rt;_} -> "[" ^ to_string str lt ^ " " ^ to_string str rt ^ "]" let%expect_test "pushes and pops" = let stack = empty |> push 1 |> push 2 |> push 3 |> push 4 |> push 5 in Printf.printf "stack: %s\n" (to_string Int.to_string stack); let rec pop_all stack = pop stack |> (function | Some (top, rest) -> Printf.printf "Popped: %d Rest: %s\n" top (to_string Int.to_string rest); pop_all rest | None -> Printf.printf "===end===" ) in pop_all stack ;[%expect{| stack: [5 [4 [3 [2 1]]]] Popped: 5 Rest: [4 [3 [2 1]]] Popped: 4 Rest: [3 [2 1]] Popped: 3 Rest: [2 1] Popped: 2 Rest: 1 Popped: 1 Rest: nil ===end=== |}] let%expect_test "use as a queue" = let stack = empty |> push 1 |> push 2 |> push 3 |> push 4 |> push 5 in Printf.printf "stack: %s\n" (to_string Int.to_string stack); let rec pop_all stack = pop_end stack |> (function | Some (top, rest) -> Printf.printf "Popped: %d Rest: %s\n" top (to_string Int.to_string rest); pop_all rest | None -> Printf.printf "===end===" ) in pop_all stack ;[%expect{| stack: [5 [4 [3 [2 1]]]] Popped: 1 Rest: [[[5 4] 3] 2] Popped: 2 Rest: [[5 4] 3] Popped: 3 Rest: [5 4] Popped: 4 Rest: 5 Popped: 5 Rest: nil ===end=== |}]
sectionYPositions = computeSectionYPositions($el), 10)"
x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
>