mirror of
https://github.com/correl/elm.git
synced 2025-01-24 03:00:32 +00:00
20 lines
389 B
Text
20 lines
389 B
Text
module Anagram (..) where
|
|
|
|
import String exposing (toLower, toList)
|
|
|
|
|
|
detect : String -> List String -> List String
|
|
detect word candidates =
|
|
let
|
|
original =
|
|
toLower word
|
|
|
|
ref =
|
|
normalize word
|
|
in
|
|
List.filter (\w -> normalize w == ref && toLower w /= original) candidates
|
|
|
|
|
|
normalize : String -> List Char
|
|
normalize word =
|
|
word |> toLower |> toList |> List.sort
|