Done day 18
authorNeil Smith <neil.git@njae.me.uk>
Sun, 27 Dec 2020 12:53:05 +0000 (12:53 +0000)
committerNeil Smith <neil.git@njae.me.uk>
Sun, 27 Dec 2020 12:53:05 +0000 (12:53 +0000)
advent18/package.yaml [new file with mode: 0644]
advent18/src/advent18.hs [new file with mode: 0644]
data/advent18.txt [new file with mode: 0644]
stack.yaml

diff --git a/advent18/package.yaml b/advent18/package.yaml
new file mode 100644 (file)
index 0000000..ce75243
--- /dev/null
@@ -0,0 +1,60 @@
+# This YAML file describes your package. Stack will automatically generate a
+# Cabal file when you run `stack build`. See the hpack website for help with
+# this file: <https://github.com/sol/hpack>.
+
+name: advent18
+synopsis: Advent of Code
+version: '0.0.1'
+
+default-extensions:
+- AllowAmbiguousTypes
+- ApplicativeDo
+- BangPatterns
+- BlockArguments
+- DataKinds
+- DeriveFoldable
+- DeriveFunctor
+- DeriveGeneric
+- DeriveTraversable
+- EmptyCase
+- FlexibleContexts
+- FlexibleInstances
+- FunctionalDependencies
+- GADTs
+- GeneralizedNewtypeDeriving
+- ImplicitParams
+- KindSignatures
+- LambdaCase
+- MonadComprehensions
+- MonoLocalBinds
+- MultiParamTypeClasses
+- MultiWayIf
+- NamedFieldPuns
+- NegativeLiterals
+- NumDecimals
+# - OverloadedLists
+- OverloadedStrings
+- PartialTypeSignatures
+- PatternGuards
+- PatternSynonyms
+- PolyKinds
+- RankNTypes
+- RecordWildCards
+- ScopedTypeVariables
+- TemplateHaskell
+- TransformListComp
+- TupleSections
+- TypeApplications
+- TypeFamilies
+- TypeInType
+- TypeOperators
+- ViewPatterns
+
+executables:
+  advent18:
+    main: advent18.hs
+    source-dirs: src
+    dependencies:
+    - base >= 2 && < 6
+    - text
+    - attoparsec
diff --git a/advent18/src/advent18.hs b/advent18/src/advent18.hs
new file mode 100644 (file)
index 0000000..1ee07f5
--- /dev/null
@@ -0,0 +1,92 @@
+-- import Debug.Trace
+
+import Data.Text (Text)
+-- import qualified Data.Text as T
+import qualified Data.Text.IO as TIO
+
+import Data.Attoparsec.Text hiding (take)
+-- import Data.Attoparsec.Combinator
+import Control.Applicative
+-- import Control.Applicative.Combinators
+
+data Expression 
+  = Number Integer
+  | Mul Expression Expression
+  | Add Expression Expression
+  deriving (Show, Eq)
+
+
+main :: IO ()
+main = 
+  do  text <- TIO.readFile "data/advent18.txt"
+      print $ part1 text
+      print $ part2 text
+
+
+part1 = parseAndEval expressionsP
+part2 = parseAndEval pExpressionsP
+
+parseAndEval parser text = sumEval $ successfulParse parser text
+
+sumEval = sum . map evaluate
+
+showE (Number x) = show x
+showE (Mul a b) = "(" ++ showE a ++ " * " ++ showE b ++ ")"
+showE (Add a b) = "(" ++ showE a ++ " + " ++ showE b ++ ")"
+
+evaluate (Number x)  = x
+evaluate (Mul a b) = (evaluate a) * (evaluate b)
+evaluate (Add a b) = (evaluate a) + (evaluate b)
+
+
+-- Parse the input file
+
+numberP = Number <$> decimal
+mulExprP = string " * " *> pure Mul
+addExprP = string " + " *> pure Add
+
+
+-- Part 1 parsing
+
+expressionsP = exprP `sepBy` endOfLine
+
+exprP = elementP `chainl1` (mulExprP <|> addExprP)
+
+elementP = numberP <|> bracketedP
+bracketedP = "(" *> exprP <* ")"
+
+
+-- Part 2 parsing
+
+pExpressionsP = pExprP `sepBy` endOfLine
+
+pExprP = pTermP `chainl1` mulExprP
+pTermP = pElementP `chainl1` addExprP
+
+pElementP = numberP <|> pBracketedP
+pBracketedP = "(" *> pExprP <* ")"
+
+
+-- chainl1 :: Parser a -> Parser (a -> a -> a) -> Parser a
+-- chainl1 p op = p >>= rest
+--     where 
+--         rest a = (do
+--             f <- op
+--             b <- p
+--             rest (f a b)) <|> pure a
+
+
+chainl1 :: Parser a -> Parser (a -> a -> a) -> Parser a
+p `chainl1` op = do a <- p
+                    rest a
+  where rest a = (do f <- op
+                     b <- p
+                     rest (f a b))
+                 <|> return a
+
+
+-- successfulParse :: Text -> (Integer, [Maybe Integer])
+successfulParse parser input = 
+  case parseOnly parser input of
+    Left  _err -> [] -- TIO.putStr $ T.pack $ parseErrorPretty err
+    Right expressions -> expressions
diff --git a/data/advent18.txt b/data/advent18.txt
new file mode 100644 (file)
index 0000000..de58882
--- /dev/null
@@ -0,0 +1,376 @@
+(3 + 8 * 9 * (4 * 6 + 3 + 4)) * 9 + 9 * 7 * ((9 * 7) + 4)
+(9 + (9 * 3 + 2 * 2 + 6 * 2) + 7 + 9) + 5
+8 * 7 * (3 + (2 * 5 + 8)) + 6 + 8 + 6
+(4 * 6 + 7 + 7 * 4 + 7) * (5 + 6 * 6 * 6 * 8) * 8 * (5 * 4 * 9 + 4 + 3 * 9) * 3
+(8 + 8 * 2) * 9 * 5 + (2 + 2 + 3 * 7 * 5 + 6) + 5
+(4 * (2 + 4) + 3 + (7 * 5 * 6 * 5 + 2 + 9)) + 8 * ((6 * 6 + 2 + 7 + 2) * (4 * 9 * 7 * 4 * 7)) + 8 * 2 * 4
+(5 + 4 + 6) * (6 * 7 + 5 * 9 * 6) * 6 + ((4 + 5 + 3 * 5 + 6) * 6 + 2)
+(4 * 7) * 2 * (2 * 9 * 6 + 8)
+7 * (3 * 4 * 5 * 8)
+(8 * (9 + 5 * 5 + 9 + 5 + 2) * 6) * (4 + 5 * 9 + (7 + 2 + 8) + 5 * 7) + 3
+(2 * 4 * (3 * 4 * 5) + 5) * 2 + (6 * 4) + ((4 * 4) * 3 + 2 * 6) + 9 * ((7 * 6 * 8 + 2 + 7 + 9) * 7 + 3 * (8 + 7) * 6)
+6 * 3 * (9 * 2 + 8)
+2 + (6 * 4) * 7 * 7
+2 + (9 + (9 + 7 + 3 * 4 + 6 * 7) * 9) * (7 * (5 * 8 + 8 + 6 + 6) * 7)
+(2 + (5 + 5 + 9 * 4) + 3) * 2 + 2 * 6 * 4
+5 * 3 * ((8 + 8 + 7 + 3 + 2) + 9)
+((9 * 4 + 5 + 7) * 8 * 3 * 6 * (7 + 8 + 8 * 7 * 5)) + 5 + 8 * 9
+(5 * 7 * 5 + (8 * 3 * 9 * 3)) * (8 + 7 + 8) + (2 + (3 * 7 + 4 * 8 + 4 * 3) * 3)
+7 + 4 * (3 + 9 * 5 + 3 * 3) * (5 * 7 + 5 + 3)
+(7 * 9 * 3 + (2 * 7 * 4 * 5 + 8 + 8)) * ((9 + 6 * 3) + 8 + (3 + 4) * 6 * 8 * 6) + 6 * 4
+4 * (3 * 4 + 3 + 4 * 4 + 9) + 5 + 8
+3 + 7 * (4 * (6 * 9 * 3 * 2 + 5 + 3) + 5) + 4 + 9
+5 + 6 * 2 * 5 + (9 + 6)
+4 * (4 * 6) + 7 * (3 * 3 + 6) * 8
+((8 + 8) + (7 + 4) + 5 * (9 * 2 * 9 * 8) * 5 * (2 + 3 * 3 + 2 * 5)) + 5 * 7 * (4 * 7 + (3 + 3 * 5 * 5 + 5 + 2) + 8 * (2 + 2 + 9 + 6 + 3)) + 2
+6 + 8 + (3 * (8 * 2 + 3) + 9 * 6 + (7 + 9 + 3 * 6) + (7 * 3 * 7))
+7 + (5 * 7 * 6 * 3) + 5
+7 + 5 + (3 + 8 * (6 + 8 * 3))
+9 + (9 + 2 * 3 + 8 * 7) + 6 + (4 + 2)
+(4 + 8 * 7 * 9 + 7 + (4 + 7 + 2 * 3)) + (2 + 7) * 6 * 6 * 6 + 9
+2 + 5 + 8
+6 + ((4 * 8) * 9 * 2 + 7)
+6 + 9 + 6 + 4 * 5 + (8 * 9 + 9 + 4 + (5 * 3 + 8 * 7 * 4 * 7) + 5)
+9 + (8 * 2 * 5 * 5 + 6)
+(4 * 3 + (2 + 3 * 6 + 2) * (9 + 8 + 2 + 8 * 6 * 2)) + 9 + 3
+((5 * 9) * (7 + 7) * 8 + 6 + 9 * 3) + (2 + 7 + 7 * 9 + 4)
+((5 + 5 * 2 + 8 + 2) * (7 + 4 + 5) * (3 + 2 + 5 + 5 + 6) * 2) * 4 * 5 + 9 * 6 * 9
+8 + (4 + (5 + 9 * 9) + 7) + ((7 * 3) + 7 * (4 + 7 * 5 + 8 + 7 + 9) * 3 * 5 + 3) + 4 * 3 * 4
+((8 * 5 * 7 + 4) + 5) + 2 + (4 + (7 * 9 + 2 * 9 + 5 + 6) + 3 + 8 * (3 + 9 * 8 + 5 + 6 + 2)) * 7
+6 * 9 * (3 + 9 + 9) + 7
+4 + 4
+(2 + (3 * 8 + 6 * 6 * 8) * 3) + ((3 + 6 + 2 * 6 * 6 + 4) * (7 * 4 + 4 * 9) + 3 + 5 * (7 * 3 * 9 * 4 + 3 + 2)) + 3
+(2 + (7 * 3 + 4 * 8)) + 5 + 2
+(3 + (8 + 9 * 2 + 4) * (9 * 7 * 8)) + (3 * 2) * 7 * 5
+5 + 7 + 3 + ((2 * 9 + 8) + 9) * 7 + 7
+(4 * 4 * 2 + (2 + 2) * 8 * 2) * 4 + (5 + 6 + 3 * 6 + 2 * 2) * 9 + 6 + 9
+9 + 9 + ((8 * 5 * 6) * 3 + 2 * 2 + (2 * 4 + 7 + 6 + 7) * 3)
+((6 * 9 + 6 * 3) * (5 * 7) + 2) + (2 + 6 + 6 + (6 * 3 * 3 * 5 * 5) * 4)
+2 * 4 + 2 + 3 + 3
+9 * 2 + 6 * 6 * 4 + 7
+3 * (4 + (6 * 5 * 7 + 7 + 4) + 6 + 8) * 8 * 3 * 6 * 2
+5 * (7 + (4 * 3 * 9) * 8 * 6) * 2
+3 + 6 + (5 + 4) * 7 * 2
+7 + (6 * 6 * 4) * 9 + 9 + 3
+9 + ((2 * 5 * 7 * 9 + 2) * (2 + 6 + 7) + 8 * 2 * 9 + 8) * (2 + 2 + 6 * 8 + (8 * 6 + 3 * 6) * 3) * 6 + 8
+(5 + 2 + 6) * (7 * 7 * 8)
+(6 * 2 + 9) + 9 * (3 + 9 * 5 + 3)
+5 + 2 + (6 + (9 + 2 + 5 * 5 * 8 + 5)) + 3 * 2 + (4 + 4 * 2 * 6)
+6 + 4 * (8 * 5 + 4 * 2) + 8
+9 * 6 * 6 + 2
+7 * (6 + 2 + 4 * 5 + 6) * 6 * (6 + (8 + 9 * 9 + 9) * 8) + 8 + (3 + 2)
+5 * 2 * (4 + 8) + 8 * 3 + (2 + 8 + 8 * 6 * 9)
+3 + 6 * (8 + (2 + 9 + 5 + 2 * 6) + 3 * 9 * 7 + 2) + 3 + 5
+(6 + 9 + 5 + 7 * (5 * 5 + 6 * 5) + 3) * 9 + 4
+4 * (3 * 9 + (9 + 9 + 6 + 7)) * 8 + (2 * 8 + 2 * (2 * 8) * 4 * (4 + 6)) * (4 * 6 * (9 * 5 + 9 * 3 * 6) * 2) + 7
+4 * 3 + (4 + 8 + 4) * 7 * 3 + 9
+4 * 8 * 3 * (3 * (9 + 9 * 8 + 3 + 4) + 8 * 6 + 6)
+2 + 8 * (5 * 4 + 3 + 9) * 2 * 8
+3 * 8 + 4 * 6 + (5 * 8 * 3 * 8)
+2 + 7 * (3 + 5 + 2 + 5) * 7 + 9 * 4
+2 * 4 + 5 * (6 * 7 + 3 * 8 + 4) + (2 * (4 + 6 + 7 + 5 * 2 * 2) + (6 * 4 * 4 + 3 + 7) + 6 + 8)
+3 + ((6 + 9 + 7) * (2 + 3) * 6) * 2 * (3 * 3 + (9 * 2 + 8) * 7) * 4 + 7
+8 * (2 + 9) * (6 + (3 * 5 + 7 * 8 + 5 + 9) * 6 * 9) * 6
+6 + 9 * 8 * 5 + (8 + 5 + 7 * (6 * 6 * 5) * 5 * 7) + (4 + 6 * 2 * 9 * 5)
+2 * 8 + 3 * 4 * (2 * 8 + 7 + (6 + 9 * 7 + 2 * 9)) * 2
+5 * (9 + (9 * 6 * 2 + 2) + 6 * 6) + (5 * 4) * 7 * 6
+((9 + 8 * 7 * 4 * 2) + 3 + 3 * 5) * 8 + 5 + 9 * 4 * 5
+9 + ((9 + 9) + 4 + 4 + 3 + 6 + (3 + 6)) + 6 * 9 + ((6 + 2 + 3) * 4)
+6 + ((3 * 5 * 4 + 6) + 6 * 5 + 4 * 9 + (3 + 9 * 2))
+3 + 3 + (7 + 8) + 8 * (4 * 9 + 8 * 9 + 9 * 9)
+(5 * 9 * 7 * 4) + 6 + 3 * 5
+(7 * 8 * 3 + 4 + (8 + 7) * 4) * 2 + 8 + 5 + 4 * 4
+9 + (8 * 6 + 2 * (8 * 6 + 4 + 2 * 5 + 2) + 4)
+(7 + 5 + (2 + 4 + 6)) + 9 + 5
+(4 + 2 * 5 * 6 + 3) * 2 + 2
+((7 * 8 * 8 + 8 + 5 * 6) * 6 * 8) * 5 * 4 * (7 + 3 * (8 + 6 + 5 + 8) * 8 + 9) * 3 * 9
+3 + 9 * 8 * (7 + 8) + (9 + 6 + 5 + (8 + 4 + 6 * 5 * 9 * 7))
+5 + 2 + 6
+(9 + 2 * 7 + (9 + 3 + 6 * 7) * (9 + 3 * 4)) + 8 * 6 + ((3 * 6 + 8 * 6) + 4 * 4 * 8) + 6 * 6
+3 + 7 * (8 + 7 * (7 * 2 + 6 + 4 + 3 * 9) + 8 * 7) * ((4 + 7) + 8 + 9 + 5) * 3 + ((2 * 8 + 2 * 3) + 3 + 8)
+8 + 5 * 9 * (5 + 3 * 4 * 8 * 8) * 7 + (2 + 9 * 4 + 4 + 3 + 8)
+6 + (9 + 4) + 4 + ((7 + 8 * 3 * 6) * 2 + 6 + 9 * 6) + ((2 + 2 + 3 + 3 + 5) * 5 + 5 + 8 + 7 + 4)
+(4 + 6 + 7 + (7 * 4 + 7 + 2 + 2)) + 4 * ((9 * 9 + 8) + 3 * 3) + 4
+5 * (4 + (6 * 9) * 2 + 5 * 8)
+(7 * 5 + (6 + 2 * 3 + 3 + 2 + 7) * 6 + 5 + 8) + 3 + 5
+(6 + 4 * 8 + 8 * (7 + 4 + 3 + 9 + 3)) * 5 + (3 + 7 + 4 + (2 + 6 + 5 * 2 + 2) + 7) * 8 + 4
+8 * ((5 * 9 * 7 * 6) * 5 + 3) * 9 * (6 * 6 * 8 * 2)
+((4 * 4) + 2) * 5 + 8
+6 * (4 + (8 + 7 + 8 + 6)) + (9 + 5 * 5 * 6 + 9)
+((5 + 9 * 6 * 7 + 7 * 3) + 8 + 2 * 8 + 9 * 5) * 2 * 9 * 4 * 6
+(7 * 5 * 9 + 4) * 3 + 5
+(5 + 5) + 8 * 9 + 2 * 8 + (7 + 4)
+8 + (4 * 7 * (7 + 5 * 3 + 7) * 9) * 8
+2 * (7 * 8 + (7 + 5 + 9 + 8)) * 9 + 9 + 9
+9 + 8 + (2 + 6 * (9 * 2 * 7 * 7) + 5 + 2 * 5) + 4 + 5
+(9 + 3 * 4 + 2 * 9) + (7 + 4 + 9)
+2 * (5 * 5 * 6 * (5 * 6 + 2 + 9 + 5 * 3)) * ((2 * 5 * 6 + 5 + 8) + 8 * 2 + 7 * 9 * 2) + 7 * 2
+9 * 2 + 7 + 3 + ((9 * 9 * 3 + 7 * 2) + 2 * 2 * (5 * 8 * 3 + 2 * 9 + 6) * 3)
+4 + (4 * 9 * 2 + 9 + 9 + 2) + 6 * 2 * (7 + 9)
+2 + 4 + (5 * 9 * 4 + (2 * 4 * 2) * (5 + 8 + 5 * 8 * 4 + 6) + 2) + 9 + 6
+(7 + 9 * 7 + 8 + 3) * 7 * 6 + (2 + 9 * 7 + 5 * 5) + 2 * ((4 + 3 * 5 + 8) + 7 * 3 * 6 * 9 * 6)
+(4 * 8 + 8 * 2) + 5 + (5 * 7 + 6 + 2 + 7 + 2) + 3
+9 * (5 * (2 + 3 + 4 * 3)) * 5 + 9 + 9 * 9
+9 * 5
+5 + (9 * 6)
+7 + 7
+3 * 4 + 3 + (7 + 3 + 4 + 8 * 4)
+8 * (5 + 3 + 3 + 2 * (4 + 6)) + (8 + 5 * 9) * 6
+5 + (2 + (6 * 2)) + 5 + 8 * 9 * 3
+(9 * 4 * 6 * (4 + 8 * 5) * 5 + 6) + 2 * 8 + 6 * (3 * (6 * 2 * 9 * 4 * 2 * 8) + 9 + (8 * 9 + 3 * 4 + 3 + 8) + 4 + 7)
+8 * (5 * 8) + (7 + 7 * 5 * 6 * 3 * 4) + (4 * 7) * (3 * 6 + 9 * 4 * 2)
+2 + (8 + 7 * 2 * (6 * 4 + 9 + 7 * 8) + 2) + 4 * 4
+2 * (7 + 3 + 2 + (9 + 4 + 8 + 9)) * 2
+9 * 8 + ((9 * 8) + 8 + 9 * 3 * 6 + 8) + 5 * 6 + (7 + (3 + 5 + 8 + 7) + 2 * (7 * 5 + 5 * 7) * (8 + 3 + 8) * 4)
+2 + 5 + 4 * (6 * 2 * (8 + 8 + 7) + 3 * 9 * 9)
+(5 * 5) + 4 * 9 + 8 * 8
+((4 + 5 * 4 + 2) + (2 * 9)) * (2 + 4 + 3 * 9) * 9 + ((2 + 7) + 9 * (3 + 6 + 2 + 3) * (7 * 8 + 5 * 6) * 9) * 8 * 6
+2 * 9 * (8 * 6 + 6) + 4 * (5 * 8 * 6 * 4)
+6 * 7 * 2 * 3 + (8 + 8) * 6
+(5 * 7) + 3
+8 * 2 * (8 + 8)
+5 * 7 + (6 + 4 * 3) + 3 + 9
+6 * 2 * 6 * 2 + 8 * 4
+(2 * 8 + 9 * 6 * (7 + 3 + 4 * 4 + 4 * 9)) + 2 + (6 + 3 * 5 + 4 + 9 + 8) + (3 * 7 + 3 * 2 + 6)
+((3 * 8 * 8 * 4 + 6 * 6) * 7) * 6
+(2 + 6 * 2 * 8 * (2 + 6 + 5 * 6) * 4) + 9 * 2 + 7
+3 + 4 * 4 + 8
+((8 * 6 * 8 + 7) * 8 * 7) * 4 + ((5 + 3 * 9 + 2 + 3 * 4) + 2 + 6 + 4 + (4 + 3 + 2)) * 7
+((6 * 9 * 4 + 5) * 5) * 7 * 3 * 7
+2 * 5 + 8 * ((6 + 5 * 6 * 5 * 3 * 2) * (7 * 7) * (8 * 3 * 3 * 3 * 8) * (6 + 8 * 9 + 9 * 4)) * 5 * 6
+6 * ((6 * 7) + 9)
+8 + 2 + 5 * 3 * ((4 + 3 + 8) + 7 + 5 * 6 * (2 * 6 * 2)) * 9
+(5 * 5 + (2 * 9 + 8) + 8 * 8 * (3 * 6)) * 9 * 3 * 2
+(9 * 8 * 7) * 7 + 7 * 4 + 8 * 7
+((3 + 8 + 2 * 7) + 3 + 7 * 2) + 4 + 3
+6 * 5 + 3 + (4 + 6 * 2 + (2 * 7)) + 2 * 2
+7 * (4 * 9 + 3 + 4 * 2 * 5) * 9 + 7 * (9 + 6 * 7 * 8) * 3
+((2 + 2) + 8 * 7 + (5 + 6 * 7 * 9 * 3) + 6 + 4) * 9
+((6 * 5 * 2 * 4) * 6 * 6 + 2 + 7 + 6) + 2
+7 * 4 + 3 * 3 * 9
+5 * ((3 + 9 * 2) * 6 * 3 * (5 * 3) * 6 + 6) * 4
+(3 * 7 * 9 + 9 * 6) * 5
+6 + (8 + 5 * 3 * (7 * 6 + 5 + 4 * 7 + 8))
+4 * 2 * 4 * (7 + 8 * (7 * 5 + 3 * 3))
+((5 + 9 + 4 * 2) * 2 * (7 * 3 + 7 + 3 * 8 + 6) + 9 + (2 + 6 + 7 * 2 * 9) * 8) + 7 * (4 + 4)
+9 + (7 * (8 * 2 + 5 * 8 + 7) * 7 + 6 + 6 * 2) * 2
+(2 * 4) + 6 + (8 * 7 + 8 * 2 + (5 * 7 + 9 + 8 * 8))
+3 + (3 + 2 * (5 * 4)) * 2 + (4 + 2 + 6 * (4 + 7 + 2)) * 3
+(9 * 6 + 9) + (9 * 8 * (4 * 6 + 5 * 6 * 4)) + 3 + 2 * (9 + 3 + 5 + 5 + (4 + 8 + 8 + 2 * 5))
+(8 + 7 * 3 + 2 * 5 * 4) * 4 * 9 + (2 + 5)
+6 * 5 + 6 * 9 + 2
+(3 * 3 + 5 * 6) + 2 * 5 * 3 + 8 * 7
+(8 + 9) * 5 * 7
+7 + (2 * 8 + (6 + 5 + 2 + 3 * 8 + 3)) * 8 * 3 * 4
+(6 + 9 * 2 * 2 + 4 * 7) + 2 * (9 + 9 + 8 + 9 + 7) + (2 + 5 * 6 * 3 + 3 + 3)
+3 + 3 + ((2 + 2 + 9 * 8 * 9) + 4 * 8 + 6 + 8 + 6) * 9 * (4 + (8 * 8 + 5 * 9 * 9 * 9) + (3 + 4) + 6 + 9) * 7
+9 + (3 + (4 + 6 + 9 * 2 * 7 * 4) * 9) + 9
+7 + (4 + 8) * 2 * 9 * 9
+6 + (9 * (5 * 4 * 3 * 5) * 4)
+3 * 8 + 4 + 2 + 5 * (4 * (8 * 6 + 2 * 5 + 8 * 4))
+(4 + 9 * 3) * 2
+5 + 3 * ((9 + 6) * 5 * (3 + 8 + 4))
+((9 + 5 * 2 + 9) + 7 + 6 + 9 * (3 + 9 + 6)) + 4 + (3 + (9 * 3 + 7 * 9) * 6 + 9 + 9)
+(9 + 6 + 6) + 3 + ((6 + 5) * 6 + 9 * 7) * (8 * (5 * 5 * 3 + 8 + 5 * 4) + (7 + 8 + 3 * 2 * 3 * 8) * 8 + 8) * (7 * (8 + 6 + 9 + 8) + 4 + 3 * 6) * 3
+6 + 2 + 4 * (5 + 6 * 6) + 6 + 5
+(2 * 7 + 5 + (4 * 4 + 8 * 5) * 4) * 6 * (4 + 2 * 2 * 3)
+9 + (8 * 8 * 8 * 2) + 8 * 5 + 5 + (3 + 6 + 4 + 6 + 6)
+(3 * (2 * 5) * 6 * 9 * 9 * (7 + 5 + 3)) + 6 + (4 + 2 * 9) * (2 * 6 + 7 + 6 + 3) + 4
+3 + 7 + 6 * 6 * (4 * (6 * 6)) + 5
+(7 + 2) + 4 * 3 * (5 + 9 + 6)
+4 * 7 * (6 * 8 * 3 * 6 + 5) + (8 * 8 * 4 + 5) * 4
+9 * 3 * 8 + 7
+3 + 7 + 3 + (6 * (2 * 2 + 7 * 4)) + 8
+5 * 6 * (7 * 9 * (4 + 8) + (5 * 3 + 7 * 4 * 7))
+3 + 4 + 2 + ((6 + 5 * 7 * 8) * 9 * 8 * 8)
+(5 + 5 * 2) * 6 + 3 * (4 * 5 + 5 * 5 * 2) + 4
+(4 + 4 + 9 * 7 * 9) * 3 + (3 * 4) + 5 * 6 + 7
+6 * (4 * 5 + 6 * 3 + 3 * 3) * 8 + 2 * 8
+3 * (3 * (4 + 3 * 2 * 5) * (2 + 4 * 5 + 8) * 5 + 3 * 8) * 6
+6 + (2 * 3 * 7 * 8 + 7) * 4
+4 * 9 * (7 + 6 + 5 * 6 * (8 * 9) + 9) + 8 * (9 * 2 + 9) + 6
+9 * 5 + 4 * ((3 + 6 * 4 + 4) + 8 + 4 + (7 + 4 * 3 + 7 * 5 + 9))
+3 + ((9 * 4 * 6 + 4) * 4 * (7 + 3 + 8 + 7 + 3 * 4)) + 7 * 4 + 5 * 6
+(8 + 2) * ((4 + 8 * 8) * 8) * 5
+2 + 8 * 8 + (5 * 7 + 3 * 4) * 4 + 4
+5 * 5 + 3 * 8 + ((7 + 5) * 3)
+(5 + 8) * (4 * 3 * 9 * 8) * 7
+(3 + 4 * (5 + 4) + 7) + (7 * 9 * 3) + 2 * 4
+2 * 3 * ((6 * 2 + 8 + 2 * 9 + 5) * 3 * (4 + 4 * 3 + 2) + 8 * (7 * 3 * 5 * 9 + 3) * 8)
+3 * 4 * (7 * 4 + 5 + 8 * 5) + ((9 * 5 * 5) + 4 + (6 * 6 + 8 * 2 + 9) * 2) + (3 + 4 + 7 * 7 + 9 * 5)
+6 * 2 + 8 * 4 * (9 * 4 + (5 * 3 + 8) + 3 + 9) + 2
+5 + (9 * 4 + 4) + (5 * 8 * 6 + 7 + 2 + 2) * 3 + (3 * (4 * 4 + 6) + 4)
+5 + 8 * (5 * 7 * 8 * 4 + 6)
+8 * 3 + 4
+6 + 2 + 5 + 4 * (9 + 2 * 9) + 5
+5 + 2 + 6 * (4 * (8 + 7 * 6 * 7) + (4 * 4 + 7) + (2 * 3 + 3 * 4 + 6 + 3) * 4 + 4) * 3
+((5 * 4 * 2 * 4 + 9) * 4 + 3 + 4 * 7 + 8) * 3 * 6 + 4 * 2
+(9 + 7) * 7 * 7 * ((6 * 3 * 4 * 8) + 9) + (7 + 4 * (3 * 3 + 6 * 2 + 7) * 9)
+9 * (7 * 4 + 9) * (8 * 2 * 5 * 7 * (8 * 3 + 9 + 3 * 4) + 6) * 2 * 3 + 3
+8 + ((3 * 5 + 3) + 5 * 7 * 8 * 8) + 3
+((9 + 3 * 5 + 2) * 6) + 9 * (5 * 5) * 6
+5 + (5 * (5 * 8) * 9 + 2) * (8 + (7 + 4 + 9 * 6 * 6 + 8)) * (4 + 8 * (6 + 6) + 7) * 3
+5 * (2 + (6 + 9 * 4) + 4 * (8 * 2 + 7) * 8 * 2) * 6 * (7 + (6 + 8 * 6 * 8) * 6)
+(7 * 7 * 5 + 8 + 2 + 3) * 3
+5 + 3 + 3 + (6 + (3 + 7)) * (4 + 6 + 9) * 8
+4 + 3 * (9 + (5 * 8 * 8 * 5 + 3) + 4 + 2 + 9)
+2 + 7 + 5 * 6 + ((4 * 6 * 9 * 2 + 2 + 5) * (7 + 2 * 4 * 7 + 8) + 8)
+(9 + 7 * 8 * (6 * 5 + 7 * 3)) + 4 * 7 + 5 * 9 + 9
+((7 * 7 + 7 + 2) + 9 + 5 + (8 + 6 * 3 * 6 + 9) * (6 * 2 + 4 * 7) * 9) + 6
+(3 + (3 * 4 * 6 + 4)) * 7
+(6 * 2 * (5 + 5 + 4 + 7 + 8)) * 6 + 4 * 4
+4 * 8 + (5 + 8) + 3
+3 + 8 + 3 * (9 + (5 * 4 * 9) * 5) * (8 + (6 * 7 * 3 + 7 * 6) * 2) * 8
+3 + 8 * (2 * 8 * 5 + 2) + 2 * ((8 + 7 * 6 + 5 + 2) * 6 * 3 * 3 * 5) * (7 * (5 + 5 + 3 * 6 * 3) * (5 * 4 + 4 * 9 + 4) + (9 + 9 + 9 * 5) + 7 * 3)
+5 + (9 + 5 + 9 + 7 + (3 + 4 + 3 * 8)) * 8
+4 * (9 + 4) + 4 + 3 + 6 + 9
+((5 * 4 * 8 * 8 + 8 + 7) + 4) + (5 * 8 + 2) * (8 * 7 * 4 + 9 * 4 + (4 * 2 * 7 + 6)) + 3 + 6
+5 * (8 + (9 * 9 * 5 * 2 + 8 + 4) * 6 + 6) + (7 * 5 * 7 * (9 * 2 * 8 + 5 * 7) * (5 + 4 + 2 * 8 * 8 * 9) * 4) + 6 + 9
+((4 * 4 * 8) + 8) * 7 * 3 + 8 * 7
+5 + 4 * 2 + 8 * (7 + 2 + 9 * 2) + 4
+5 * (4 + 9 + (3 * 4 * 5) * 9)
+4 + 2 + 3 * 3 + 9 * (9 + 4 * 9)
+5 * 4 + 3 * 8
+(8 + 4 * 6) * (8 * 3 + 4 * 8 * 9 * 2)
+(9 + (8 + 4)) * 6
+(9 + 5 * 5 * 8 + 7 * (9 * 6 * 6)) + 2 + 4 * 2 * (3 * 8 * (5 * 5 + 5 * 7) + 8 + (3 + 7 * 5 + 4 * 5) + 5) + 9
+3 * 9 + 2 * (7 + 8 + (9 * 6 + 4) * (4 + 8 * 9 + 2 + 3) + 3)
+(4 + 7) * 3 + 7 * 5
+6 * (4 * 5 + (2 + 7 * 8 + 9 + 5) * 7 + 9 * 2) + 8
+8 * (8 * 3 * (3 * 3 + 2) + 9) * 5 + (7 * 3 * 2 * 4)
+9 + 3 + 4 * (8 + 4 * (2 * 8 * 3) * (5 * 4) * 7 + 5) * 8
+8 * 9 + 6 * (3 * (6 * 8 * 6) + 7 + 9 * 5 * 7) * (7 * 3 + 3 * 6 * 8)
+8 + (8 * 6 + 7 + 2 * (4 * 6 * 3))
+4 + 2 * 7 * ((7 + 6 + 7) * 8 * 6) * (2 * 7 * (2 + 4 + 9 + 2) * (4 + 3 + 6 + 2 + 6) + 6 + 7)
+(3 + 9) * 7 + 5 * (3 + 3 * 2 * 6) * 3 * 2
+(5 * (8 * 3 + 6 + 5 * 9) * 8 * 6 + 9 * 9) + 8 + 5
+8 + ((9 + 3 + 2) * (7 + 9 * 6 * 3) + (4 + 6 * 5 + 8 + 3) * (6 + 9)) + 9 * 7 * 7
+2 + 9 * 3 * ((6 + 3 + 3 + 6 * 7 + 9) + 8 + (5 * 5) * (4 * 8 * 5) * 3)
+8 + 6 + 4 * 2 * ((5 * 8 + 9 * 2 * 3) * 3 * 9 + 4 * 9 + (3 + 5 * 9)) + 2
+7 * ((6 + 8 + 5) + 9) * 4 + 4
+9 + 3 * 4 * (6 + (9 * 3 + 7 * 3 + 7 + 3)) * (4 * (4 * 3 + 4))
+7 * (5 + 7 * 5) + 2 + ((7 + 6 * 7 * 9) + 5 + 3 + 9 + 6) * (7 + 4) * 2
+2 + 4 * 5 + 6 * 3
+2 * 9 * ((9 * 5 * 8) + (8 + 3 * 8)) + (7 * 8)
+7 * 6 + 5 + (5 * 4) + 9 * 2
+4 * 5 + 2 + (4 * 4 * 7) + 4
+5 + 5 + 2 * (8 * (3 + 5 + 9 + 4) + 7) * 3
+3 + ((2 * 8 + 7 * 3 * 3 * 4) * 3 + 9) + ((6 * 9 * 4) + 4) * 8 * 6
+((2 * 5 + 4) * 2 + (3 + 4) * 8) * 7 * 9 + 2 + (9 * 7 * 8 + 5 + 9) + 8
+7 * (9 * (5 * 3 * 2) * 7 * 5 + 3 + 7) + 7 * 9 * 3 + 6
+((3 * 3) * 7 + 9 * 7) * 6 * 8 + (4 * 3 + (7 + 4 * 2) * (5 * 9 * 6 + 4 + 6 + 4)) * 2
+3 * 6 * 2 + ((4 * 9 + 7) + 6) * 3
+9 * (3 + 8) * 6 * 3 * 7 * (4 * 3 + 7 * 2 + (8 + 7 * 6 * 2 * 8 + 3) * 3)
+((5 * 4 * 5 * 6) * 8 * 8) + 8
+((2 * 9 + 2 + 6 * 5) * 4 * 2 * (4 + 4 * 9 + 3 * 2 * 8)) * 4 * 7 * 3 + 4 + 7
+6 * 3 + 5 * 4 + 8 + 9
+8 * 2 + (7 + (6 + 4) * (6 * 5) * 3 * 7 * 8) * 2 * 9 + 5
+6 + (3 * 2 * 9 * 8 * 5) * 2 + 6 + ((6 * 8 * 7 + 5 * 9) + 3 * 3) * 5
+(8 + 3) + 3 * (3 * 3 * 7) + 8 * 8 + 3
+6 + 2 * (2 + 2 + 9 * 2)
+(7 * 2 * 6 * 3 * 4 + (7 + 6 + 6 + 3 + 2 * 7)) * 8
+(7 + 2 + 2 + (9 + 8) + 3) + (4 + (5 + 7 * 6 * 2) + 7 + 9 + (2 * 8 * 4 * 3 + 6)) * (6 * (9 * 6 + 4 + 7) + 8) * 6 + 2 * 6
+6 + 5
+(9 * (6 * 9 * 2 + 3 + 5) + 7 + 2 + 4) + 8 * (6 + 5 * 9)
+8 * (5 * 8) + 5
+9 * 2 * 9 * 9 + 7
+(8 + 9 + (8 + 7 * 4 + 4) + 4 + 2) + 6 * ((9 + 4 * 9 * 3 + 5 + 2) * 8 * 3 * 8 * 3) + 8
+5 + (8 * 4 * 5)
+(3 * 7 * 4) + 6 * 8 * (5 + 4 + 8 + 5) * (4 + 8 + 9 * 8 + 7 * 7) + (4 * 8 + (5 + 4 + 2 * 2))
+9 + 6 * 7 + 2 * (9 * (3 + 2 + 7 * 9) * 3 * 4 * (6 * 6 * 9 + 4)) + 9
+7 + (8 * (5 + 7 * 6) * 8 + (2 * 4 + 5 * 4 + 6 * 7) + 3) + 9
+5 + 7 * (3 + 8 + 2 * 8 * 5 + 4) * 7 * 8 + 8
+9 * 4 * 4
+(9 * 3) * ((5 * 7) * 8 * 2 + 4) + 5 + 9 * 3 + 5
+((2 * 5) + 2 + (7 * 5 * 9) * 2 + 5) + 7 + (5 + 2 + (8 + 4 * 4 + 6))
+((5 + 4 + 9) * 4 * 4 * 6) * 4 * 6 + 5
+4 * 8 + 3 * ((8 + 8) * 5 * 7 + 9)
+8 * 6 + 5 + (5 * 9 + 5 * 7 * (9 + 8 * 7) * 5)
+7 * (3 + 4 * (3 + 6) + 6 + (3 * 8) * 9) + ((8 * 5 + 3 * 8) + 2 + 3) + (9 + 6 * (6 + 8 + 6 * 8 + 8 + 6)) * 2 * 7
+8 + ((6 + 6 + 5 + 3 * 3) * 5 * 8 + 9) + 2
+((9 + 8 * 8) * 8 + (6 + 2 + 7 + 3 * 3 + 6) + 2) * ((2 + 3 * 7 + 6) + 3 * 7 + 8 + 6 * 6) * 3 * 8 + 9
+5 + (8 * (4 * 2) * 2 + 9) * 2 * 6
+(4 + 4 * 9) + (6 + 5 * (4 + 2 * 2 * 4 * 8) * 2 + 4)
+6 + 7 + 5 + (6 * (2 + 6 * 2 + 5 + 9)) * 6
+5 * 3 + 2 + 2 * ((7 + 6 * 8 + 6 * 7 + 5) * 4)
+6 * (7 * 8) * (6 + 6 + 2 + 4 + 6 + 6)
+((7 + 3 * 7 * 4) + 7 + 9 * 4) + 4 * (2 * 9 * 7 + (3 + 9 * 3)) + 8 * 9
+2 * 3 * 2 * 5 + 9 * 6
+((3 * 7 * 9 + 4 + 5 + 3) * 8 + (4 + 5 + 8 + 3) + 2 * 2) * 7 * 5
+3 + ((8 * 2) + 8 * 4 + 2) * 4 + 9 * 5 + 5
+3 + 9 + (6 * 9 * 8) * ((8 * 3 + 9) * 4 + 5 * 7 + 6) + 7
+9 + (8 * 4 + 2 * 6 * 4 * 4) * 9
+5 + 3 + 5 * 3 + 4 * 3
+(5 * 3 * 4) + 7 + 8 + 6 + 5
+(6 * (9 * 7 + 5) + 7 * 4) * 2 * 9 + (7 + 5 * 4 + 7 + 3 * 6)
+6 * 9 + 2 * 2 + (6 + (6 * 6 + 2 * 4 + 8) + 7 * 5)
+((5 * 9 + 3 * 6) + (5 + 2 + 3 * 4) + 3 + 8) * (9 * 2 + 7 * (8 * 5)) * 6 * 2 + 5
+(9 + (5 + 7 + 2 * 9) * 4 * 2) * 5 * 5 + 7 + 7 + 9
+9 + 7 + 4 + (9 * 7 + 2 * (5 + 4 + 3 * 4))
+6 + (3 + 5 * 4 * 8 + (7 + 4 * 3 * 4)) * 7 * 4
+9 * ((7 + 6 * 3 * 6) * 7 + (4 * 5 * 3)) + 9 + (7 * 6 + 8 * 5) + 9
+4 + 7 * 6 + 6 + (7 + (7 + 8 * 7 + 8 * 4 * 9) + 3 * 9) + 7
+(9 + 7 + 2) * 3 + (7 * 8 + 9)
+2 + 4 * (2 * 8 + (7 + 5) * 6) + 4 + 4 + (3 + 2)
+(5 + (2 * 4 + 9 * 6) * 9 + 3 * 7 * 3) + (5 + (2 * 4 + 7 + 6) * 4 + 3 + 2) * (7 + 9 + (6 * 9 + 6 * 9) + (2 * 2 + 5 + 5) * 4 + 7)
+(8 * 6 * 8 * 7 + 7 + 6) + 8 + 9
+6 + (3 * 4 + 6) + 9
+5 * 2 * 6 + 2 + (4 * 8 * 2 + (4 + 7 + 3 * 8 + 2)) * (4 + 8)
+(4 + 2 + 7) + (7 * 2 * 3 * 8)
+(9 * 6 * 2 * 9 * 7) * 4 + 4 * 4 + 4 * 8
+9 * 3 * (9 + (5 + 3 + 2 + 6)) + (8 * 6 * 4) * 8
+8 + (6 + 3 * 6) * 2 * 8
+5 * 4 * 3 + (9 * 8 + 6)
+(2 + 4 * 8 * 9 * 9 * 2) + 7 + 7 + 3 * 8
+(2 * (4 + 7 + 8 * 4) * 4 * 6 * 7 + 4) * 6 + 5 * (6 + 4 * (6 + 9 * 2 + 2) + 2 + 5) * 4 * 5
+(9 + 4 * 8 * 8) * 8 * (6 + (8 * 5) * (2 * 7 * 4 + 4 * 6) + 3 + 4 + 9) + 9 * 9 + 4
+(7 * 4 + 3) + 4 + 7 * 9 * 7 + (6 * 3)
+4 * 2 + 8 + (3 * 2 * (4 * 8) + 3)
+6 + 6 * 3 + (9 * 5 * 5 + 4 + 9 * 9) * 3
+2 + 8 * (2 + 8 + 2) + (8 * 6 * (3 * 6 * 4 + 8 * 6 * 6) + (3 + 5 + 7 * 8)) * 9 * (4 * 9 * 5 * 6 * 5 * 7)
+4 + ((8 + 9 * 5 * 6) + 3 + 9)
+(5 + 5 + 5 * 6 * (6 * 5)) * 7 * 2
+4 + 6 + (7 * 2 * (9 * 7 * 5 + 5) + 4 * 2) + 9 * 9 * 2
+6 + 9 * 8 * 3 + 9 * (3 * (3 * 2 + 2 + 9 + 7) * 2 + 2 + 3 * 8)
+8 * 6 * (9 + 7 * (8 * 9 + 7)) + 8 * (3 + 3 + (4 * 2) + 4 * 7 + 4) * 4
+9 * 2 + 2 * 4
+(6 + (6 + 9 + 3 + 5 + 6)) * 8 + 8 + 3 * 8 * 9
+(8 + 2) + 3 * ((2 + 2 * 5 * 2 + 9 + 6) * 6 * 6 + 3 + 3 + (5 + 9 + 7 + 5 + 9)) * 2 * ((4 * 7 + 4) * 6)
+(4 + 8 * (9 + 8) + 2 + 4 * 2) + (7 + 5 + 3 + 9 * 4)
+8 * 5 + 8 + (7 + 2 + 8 + 7 + 8) * (9 * 7)
+7 + (9 * (9 * 4 * 8)) + (8 + 8 * (2 + 6 + 2 + 6) + (7 * 9 * 2 + 3 + 8 + 7)) * ((5 + 4) + 6 + 3) * 2 + 7
+6 + ((4 + 2 * 5) + 3 * 7) * 2 + (4 + 9) * 3 + 3
+9 * 4 + 7
+((5 + 6 + 6 * 3 * 5 * 8) + 8 + 4) * 6 * 5 * 4
+6 + ((4 + 7 * 6 * 4) + 8 * 2 + 6)
+7 + 4 * 8 * 8 * 3 * (7 * 6 + 6 + (8 * 6 * 9))
+((8 * 5 + 7 + 3 + 7) + 3 + 7 * (4 + 2 * 9)) + (7 * 6 + 2 + 5 + 6) + 2 * 6
+(9 + 4) + 2 + 8 * (6 + (7 + 8 * 9 + 6 * 8) + 6) + 3
+6 + (6 * 7 + 3 * 7 * (2 + 2 * 2 * 2) * 8) * (2 * 6 * 7 + 4 * (9 + 9 * 3 + 4) + 4) * 6
+(6 + 9 + 6 + 8 * 5) * 8 * ((4 * 9 + 2 + 7 * 6 + 4) + (7 + 2 * 4 + 5)) * 3
+((9 * 8 + 9 + 8 * 2 * 3) + 7 * (4 * 6 + 7 * 3 + 2 * 3) + 9) * 7 * 9
+(3 + 6 + 7 + 9) * (2 + (4 * 7 * 6 + 9 + 3 + 5) + 9 + (2 + 3 + 7 + 4 + 3) + 9) + 8
+(6 + 8 * 2) + 3 + 7 * 5
+7 * (5 + 4 * 5 + 9 + 6 * (3 + 4 + 4 + 8 + 4))
+(4 + 7 * 5 + 4 + 6) + (3 + (5 + 4)) * 3 * (2 * 4) + 2 + 6
+(6 * 4) + 8 * (4 * (8 + 7 + 3)) + 4
+5 + 6 * 8 + 3 + (7 * 5 + 5)
+7 + 2 * 5 * ((8 + 4 * 8 + 3 * 5) + (8 + 4) * 6 + 4 + 9 * 4) * 8
+(3 * 3 * (7 + 7 * 7 + 7) * 5 * 9 * 9) * 4 * (5 * 2 * 9 + 8 * (4 + 2) * 7) * 9 + 8 * 4
+5 * 7 + (7 * (2 * 4))
+3 + (9 + (5 * 9)) + 8 * 4
+9 * 5 * 3 + 3 + 3 * (9 * 6 * 6 + 2 * 4)
+2 + ((2 * 7 + 4 * 4) + 8 * 6 * (9 + 4))
+9 + (8 + (7 * 5 * 7 * 5 * 7)) + 2
+(4 * 5 * 6 * 3) + 9
+6 + (2 * 5 * 9 + 8 + 2) * (2 * 8 * 3 * 2)
+3 * (5 * (3 * 5 + 3) + 5 + (2 + 6 * 8 * 2 + 4 + 6) * 2) * 9 * (6 + 6 + 3) * 2
+(2 + 5 + 8) + (2 + 8 + 3 * 7 + 4) * 3 + 3 * 9
+6 * 6
+5 * 9 * ((6 * 5 + 9 + 9) * 6) * 4
+5 + 5 * 6 + (3 * 5) + 5
+3 + (8 + 8 * (6 + 9 * 4 + 8 * 6) + 6 + 7 * 3) + 2 + 8 * 6 * 7
+(3 * 2 + 6 * 3) * 7 * 6 * 9 + 5
+2 + ((6 + 4 + 7 + 5 * 3 * 8) * 3 * 5)
+(3 * 9 * 5 + 3 + 2) * 4 + 8 + (6 + 3 * 8 * 8) * (7 + 5 + 8) + (8 + 9)
+5 * 2 + 2 * 8 * 5 * (2 * 5)
\ No newline at end of file
index d9fee510c11ce7c12f70d92bd15fddfc568c943e..ba78e950745e2b5d1243763ba46d7be62394d440 100644 (file)
@@ -52,6 +52,7 @@ packages:
 - advent15
 - advent16
 - advent17
+- advent18
 
 # Dependency packages to be pulled from upstream that are not in the resolver.
 # These entries can reference officially published versions as well as