Skip to content

Instantly share code, notes, and snippets.

@MiyamonY
Created February 27, 2015 13:27
Show Gist options
  • Save MiyamonY/2d7c1ffd60dc8fb5aba0 to your computer and use it in GitHub Desktop.
Save MiyamonY/2d7c1ffd60dc8fb5aba0 to your computer and use it in GitHub Desktop.
import Data.List
data Section = Section {getA :: Int, getB :: Int, getC :: Int }
deriving (Show)
type RoadSystem = [Section]
heathrowToLondon :: RoadSystem
heathrowToLondon = [Section 50 10 30,
Section 5 90 20,
Section 40 2 25,
Section 10 8 0]
data Label = A | B | C deriving (Show)
type Path = [(Label, Int)]
roadStep :: (Path, Path) -> Section -> (Path, Path)
roadStep (pathA, pathB) (Section a b c) =
let timeA = sum (map snd pathA)
timeB = sum (map snd pathB)
forwardTimeToA = timeA + a
crossTimeToA = timeB + b + c
forwardTimeToB = timeB + b
crossTimeToB = timeA + a + c
newPathToA = if forwardTimeToA <= crossTimeToA
then (A, a): pathA
else (C, c) :(B, b):pathB
newPathToB = if forwardTimeToB <= crossTimeToB
then (B, b) : pathB
else (C, c) : (A, a) : pathA
in (newPathToA, newPathToB)
optimalPath :: RoadSystem -> Path
optimalPath roadSystem =
let (bestAPath, bestBPath) = foldl roadStep ([], []) roadSystem
in if sum (map snd bestAPath) <= sum (map snd bestBPath)
then reverse bestAPath
else reverse bestBPath
groupsOf :: Int -> [a] -> [[a]]
groupsOf 0 _ = undefined
groupsOf _ [] = []
groupsOf n xs = take n xs : (groupsOf n . drop n $ xs)
-- undefined :: a
main :: IO ()
main = do
contents <- getContents
let threes = groupsOf 3 . map read . lines $ contents
roadSystem = map (\ [a, b, c] -> Section a b c) threes
path = optimalPath roadSystem
pathString = concat $ map (show . fst) path
pathTime = sum $ map snd path
putStrLn $ "The best path to take is :" ++ pathString
putStrLn $ "Time taken :" ++ show pathTime
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment