Sha256: addef340a27f7d447bad669bd07fac46ae330a90add5cea2c11f38178831c1c5

Contents?: true

Size: 946 Bytes

Versions: 396

Compression:

Stored size: 946 Bytes

Contents

module Change (findFewestCoins) where

import Data.List (sortBy)

type Coin = Integer
type Coins = [Coin]
type Amount = Integer

findFewestCoins :: Amount -> Coins -> Maybe Coins
findFewestCoins target coins = minChange target sortedCoins [] Nothing
  where
    sortedCoins = sortBy (flip compare) coins

    minChange target' coins' candidate bestResult
      | target' < 0 || worseResult = bestResult
      | target' == 0 = Just candidate
      | otherwise = dropCoin target' coins' candidate newBestResult
      where
        worseResult = maybe False (\x -> length x <= length candidate) bestResult
        newBestResult = addCoin target' coins' candidate bestResult

    addCoin target' coins'@(coin:_) candidate
      | newTarget >= 0 = minChange newTarget coins' (coin:candidate)
      where newTarget = target' - coin
    addCoin _ _ _ = id

    dropCoin target' (_:restCoins) = minChange target' restCoins
    dropCoin _ _ = flip const

Version data entries

396 entries across 396 versions & 1 rubygems

Version Path
trackler-2.2.1.139 tracks/haskell/exercises/change/examples/success-standard/src/Change.hs
trackler-2.2.1.138 tracks/haskell/exercises/change/examples/success-standard/src/Change.hs
trackler-2.2.1.137 tracks/haskell/exercises/change/examples/success-standard/src/Change.hs
trackler-2.2.1.136 tracks/haskell/exercises/change/examples/success-standard/src/Change.hs
trackler-2.2.1.135 tracks/haskell/exercises/change/examples/success-standard/src/Change.hs
trackler-2.2.1.134 tracks/haskell/exercises/change/examples/success-standard/src/Change.hs
trackler-2.2.1.133 tracks/haskell/exercises/change/examples/success-standard/src/Change.hs
trackler-2.2.1.132 tracks/haskell/exercises/change/examples/success-standard/src/Change.hs
trackler-2.2.1.131 tracks/haskell/exercises/change/examples/success-standard/src/Change.hs
trackler-2.2.1.130 tracks/haskell/exercises/change/examples/success-standard/src/Change.hs
trackler-2.2.1.129 tracks/haskell/exercises/change/examples/success-standard/src/Change.hs
trackler-2.2.1.128 tracks/haskell/exercises/change/examples/success-standard/src/Change.hs
trackler-2.2.1.127 tracks/haskell/exercises/change/examples/success-standard/src/Change.hs
trackler-2.2.1.126 tracks/haskell/exercises/change/examples/success-standard/src/Change.hs
trackler-2.2.1.125 tracks/haskell/exercises/change/examples/success-standard/src/Change.hs
trackler-2.2.1.124 tracks/haskell/exercises/change/examples/success-standard/src/Change.hs
trackler-2.2.1.123 tracks/haskell/exercises/change/examples/success-standard/src/Change.hs
trackler-2.2.1.122 tracks/haskell/exercises/change/examples/success-standard/src/Change.hs
trackler-2.2.1.121 tracks/haskell/exercises/change/examples/success-standard/src/Change.hs
trackler-2.2.1.120 tracks/haskell/exercises/change/examples/success-standard/src/Change.hs