Difference between revisions of "99 questions/Solutions/82"
< 99 questions | Solutions
Jump to navigation
Jump to search
(Solution to Problem 82 using list comprehension added) |
(No difference)
|
Revision as of 04:14, 25 February 2012
Brute-force search from the source, using list comprehension:
import Data.List (partition) cycle' :: Int -> [(Int, Int)] -> [ [Int] ] cycle' n g = search n [] where search [] result = result search cur result = search (go active) (arrive ++ result) where split = partition end cur end s = (last s == n) && (length s /= 1) active = snd split arrive = fst split go ls = [ x ++ [snd y] | x <- ls, y <- g, last x == fst y, not (snd y `elem` tail x)]