Sha256: bb51c774b47b47656ea35c00d94435585ce963feb76dd13594ad752cdb33a1bc

Contents?: true

Size: 490 Bytes

Versions: 253

Compression:

Stored size: 490 Bytes

Contents

module BinarySearch
  ( find
  ) where

import Prelude
import Data.Array (length, (!!))
import Data.Maybe (Maybe(Just, Nothing))

find :: Int -> Array Int -> Maybe Int
find i a = go 0 (length a - 1)
  where go l h | l > h = Nothing
        go l h =
          let m = l + (h - l) / 2
          in case a !! m of
               Nothing -> Nothing
               Just j | j == i    -> Just m
                      | j < i     -> go (m + 1) h
                      | otherwise -> go l (m - 1)

Version data entries

253 entries across 253 versions & 1 rubygems

Version Path
trackler-2.2.1.78 tracks/purescript/exercises/binary-search/examples/src/BinarySearch.purs
trackler-2.2.1.77 tracks/purescript/exercises/binary-search/examples/src/BinarySearch.purs
trackler-2.2.1.76 tracks/purescript/exercises/binary-search/examples/src/BinarySearch.purs
trackler-2.2.1.75 tracks/purescript/exercises/binary-search/examples/src/BinarySearch.purs
trackler-2.2.1.74 tracks/purescript/exercises/binary-search/examples/src/BinarySearch.purs
trackler-2.2.1.73 tracks/purescript/exercises/binary-search/examples/src/BinarySearch.purs
trackler-2.2.1.72 tracks/purescript/exercises/binary-search/examples/src/BinarySearch.purs
trackler-2.2.1.71 tracks/purescript/exercises/binary-search/examples/src/BinarySearch.purs
trackler-2.2.1.70 tracks/purescript/exercises/binary-search/examples/src/BinarySearch.purs
trackler-2.2.1.69 tracks/purescript/exercises/binary-search/examples/src/BinarySearch.purs
trackler-2.2.1.68 tracks/purescript/exercises/binary-search/examples/src/BinarySearch.purs
trackler-2.2.1.67 tracks/purescript/exercises/binary-search/examples/src/BinarySearch.purs
trackler-2.2.1.66 tracks/purescript/exercises/binary-search/examples/src/BinarySearch.purs
trackler-2.2.1.65 tracks/purescript/exercises/binary-search/examples/src/BinarySearch.purs
trackler-2.2.1.64 tracks/purescript/exercises/binary-search/examples/src/BinarySearch.purs
trackler-2.2.1.63 tracks/purescript/exercises/binary-search/examples/src/BinarySearch.purs
trackler-2.2.1.62 tracks/purescript/exercises/binary-search/examples/src/BinarySearch.purs
trackler-2.2.1.61 tracks/purescript/exercises/binary-search/examples/src/BinarySearch.purs
trackler-2.2.1.60 tracks/purescript/exercises/binary-search/examples/src/BinarySearch.purs
trackler-2.2.1.59 tracks/purescript/exercises/binary-search/examples/src/BinarySearch.purs