finish eight
This commit is contained in:
parent
da4ae2a835
commit
a647a0293f
61
app/eight.hs
Normal file
61
app/eight.hs
Normal file
|
@ -0,0 +1,61 @@
|
|||
import Data.Char
|
||||
|
||||
type TreeHeight=Int
|
||||
data Tree = Tree TreeHeight [TreeHeight] [TreeHeight] [TreeHeight] [TreeHeight] deriving(Show)
|
||||
|
||||
parseTrees :: [[TreeHeight]] -> [TreeHeight] -> [[TreeHeight]] -> [Tree]
|
||||
parseTrees linesAbove heights linesBelow = do
|
||||
let heightsWithIndex = zipWith (,) heights [0..]
|
||||
let trees=map (\heightWithIndex -> do
|
||||
let (_,columnAbove) = getAlingedHeightsInColumn (linesAbove) heightWithIndex
|
||||
let (_,columnBelow) = getAlingedHeightsInColumn linesBelow heightWithIndex
|
||||
let (rowBefore,self:rowAfter) = splitAt (snd heightWithIndex) heights
|
||||
Tree (fst heightWithIndex) columnAbove columnBelow (reverse rowBefore) rowAfter ) heightsWithIndex
|
||||
let recrusiveResult = if (0 == length linesBelow) then [] else
|
||||
(parseTrees (heights:linesAbove) (head linesBelow ) $ tail linesBelow)
|
||||
trees <> recrusiveResult
|
||||
|
||||
isVisible :: Tree -> Bool
|
||||
isVisible (Tree height columnAbove columnBelow rowBefore rowAfter) =
|
||||
canBeSeen columnAbove ||
|
||||
canBeSeen columnBelow ||
|
||||
canBeSeen rowBefore ||
|
||||
canBeSeen rowAfter
|
||||
where canBeSeen = all (< height)
|
||||
|
||||
|
||||
getTreeViewingScore :: Tree -> Int
|
||||
getTreeViewingScore (Tree height columnAbove columnBelow rowBefore rowAfter) =
|
||||
foldl (*) 1 $ map (scoreInOneDirection height) [columnBelow,columnAbove,rowAfter,rowBefore]
|
||||
|
||||
scoreInOneDirection :: TreeHeight -> [TreeHeight] -> Int
|
||||
scoreInOneDirection height heights =let (a,b,c) = (foldl foldFunc (-1,0,True) heights) in b
|
||||
where foldFunc :: (TreeHeight,Int,Bool) -> TreeHeight -> (TreeHeight,Int,Bool)
|
||||
foldFunc (currentHeight,count,canSee) nextHeight
|
||||
| not canSee = (currentHeight,count,canSee)
|
||||
| nextHeight >= height = (currentHeight,count+1,False)
|
||||
| nextHeight >= currentHeight = (max nextHeight currentHeight,count+1,True)
|
||||
| nextHeight < currentHeight = (currentHeight,count+1,True)
|
||||
|
||||
|
||||
|
||||
getAlingedHeightsInColumn :: [[TreeHeight]] -> (TreeHeight,Int) -> (TreeHeight,[TreeHeight])
|
||||
getAlingedHeightsInColumn rows ((ownHeight,index)) = (ownHeight, map (!! index) rows)
|
||||
|
||||
mainP1:: IO ()
|
||||
mainP1 = do
|
||||
content <- readFile "eight-input.txt"
|
||||
let (firstRow:rest) = (map digitToInt) <$> lines content
|
||||
let trees = parseTrees [] firstRow rest
|
||||
print $ length $ filter isVisible trees
|
||||
|
||||
mainP2:: IO ()
|
||||
mainP2 = do
|
||||
content <- readFile "eight-input.txt"
|
||||
let (firstRow:rest) = (map digitToInt) <$> lines content
|
||||
let trees = parseTrees [] firstRow rest
|
||||
mapM (print) trees
|
||||
print $ maximum $ map getTreeViewingScore trees
|
||||
|
||||
|
||||
main=mainP2
|
Loading…
Reference in a new issue