Sha256: 9d2fe949d90cb7cf2cbc4fe72144926bc255ab72893a6cc522e2a371502ddc3f

Contents?: true

Size: 379 Bytes

Versions: 151

Compression:

Stored size: 379 Bytes

Contents

open Core

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

151 entries across 151 versions & 1 rubygems

Version Path
trackler-2.1.0.53 tracks/ocaml/exercises/binary-search/example.ml
trackler-2.1.0.52 tracks/ocaml/exercises/binary-search/example.ml
trackler-2.1.0.51 tracks/ocaml/exercises/binary-search/example.ml
trackler-2.1.0.50 tracks/ocaml/exercises/binary-search/example.ml
trackler-2.1.0.49 tracks/ocaml/exercises/binary-search/example.ml
trackler-2.1.0.48 tracks/ocaml/exercises/binary-search/example.ml
trackler-2.1.0.47 tracks/ocaml/exercises/binary-search/example.ml
trackler-2.1.0.46 tracks/ocaml/exercises/binary-search/example.ml
trackler-2.1.0.45 tracks/ocaml/exercises/binary-search/example.ml
trackler-2.1.0.44 tracks/ocaml/exercises/binary-search/example.ml
trackler-2.1.0.43 tracks/ocaml/exercises/binary-search/example.ml
trackler-2.1.0.42 tracks/ocaml/exercises/binary-search/example.ml
trackler-2.1.0.41 tracks/ocaml/exercises/binary-search/example.ml
trackler-2.1.0.40 tracks/ocaml/exercises/binary-search/example.ml
trackler-2.1.0.39 tracks/ocaml/exercises/binary-search/example.ml
trackler-2.1.0.38 tracks/ocaml/exercises/binary-search/example.ml
trackler-2.1.0.37 tracks/ocaml/exercises/binary-search/example.ml
trackler-2.1.0.36 tracks/ocaml/exercises/binary-search/example.ml
trackler-2.1.0.34 tracks/ocaml/exercises/binary-search/example.ml
trackler-2.1.0.33 tracks/ocaml/exercises/binary-search/example.ml