Sha256: 47a1234625d4ed997511eb7eff64d992e10c6204fe9457be3ed3bfdaca7ea061

Contents?: true

Size: 379 Bytes

Versions: 68

Compression:

Stored size: 379 Bytes

Contents

open Base

let find xs value = 
  let rec go lo hi = 
    if lo > hi then None
    else begin 
      let mid = lo + (hi - lo) / 2 in
      let mid_val = xs.(mid) in
      if mid_val < value
      then go (mid + 1) hi
      else if mid_val > value
      then go lo (mid - 1)
      else Some mid
    end
  in
  if Array.is_empty xs
  then None
  else go 0 (Array.length xs - 1) 
  

Version data entries

68 entries across 68 versions & 1 rubygems

Version Path
trackler-2.2.1.159 tracks/ocaml/exercises/binary-search/example.ml
trackler-2.2.1.158 tracks/ocaml/exercises/binary-search/example.ml
trackler-2.2.1.157 tracks/ocaml/exercises/binary-search/example.ml
trackler-2.2.1.156 tracks/ocaml/exercises/binary-search/example.ml
trackler-2.2.1.155 tracks/ocaml/exercises/binary-search/example.ml
trackler-2.2.1.154 tracks/ocaml/exercises/binary-search/example.ml
trackler-2.2.1.153 tracks/ocaml/exercises/binary-search/example.ml
trackler-2.2.1.152 tracks/ocaml/exercises/binary-search/example.ml
trackler-2.2.1.151 tracks/ocaml/exercises/binary-search/example.ml
trackler-2.2.1.150 tracks/ocaml/exercises/binary-search/example.ml
trackler-2.2.1.149 tracks/ocaml/exercises/binary-search/example.ml
trackler-2.2.1.148 tracks/ocaml/exercises/binary-search/example.ml
trackler-2.2.1.147 tracks/ocaml/exercises/binary-search/example.ml
trackler-2.2.1.146 tracks/ocaml/exercises/binary-search/example.ml
trackler-2.2.1.145 tracks/ocaml/exercises/binary-search/example.ml
trackler-2.2.1.144 tracks/ocaml/exercises/binary-search/example.ml
trackler-2.2.1.143 tracks/ocaml/exercises/binary-search/example.ml
trackler-2.2.1.142 tracks/ocaml/exercises/binary-search/example.ml
trackler-2.2.1.141 tracks/ocaml/exercises/binary-search/example.ml
trackler-2.2.1.140 tracks/ocaml/exercises/binary-search/example.ml