-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathday11_part02.fs
54 lines (46 loc) · 1.87 KB
/
day11_part02.fs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
module day11_part02
open System.Text.RegularExpressions
open AdventOfCode_2016.Modules
type Element =
| Generator of string
| Microchip of string
| Nothing
let buildElement (value: string) =
let parts = value.Split(" ")
match parts[1] with
| "generator" -> Generator(parts[0])
| "microchip" -> Microchip(parts[0].Split("-")[0])
| _ -> Nothing
let parseLine (line: string) =
let pattern = @"(\b[\w-]+\b)\s(?:generator|microchip|relevant)"
let match' = Regex.Matches(line, pattern)
let elements =
match'
|> Seq.map (fun m -> buildElement m.Value)
|> List.ofSeq
elements
let parseContent (lines: string array) =
let elements = lines |> Array.mapi(fun idx line -> (idx, parseLine line))
elements
let moveElements(elements: (int*Element list) array) =
let elementsByFloor = elements |> Array.mapi(fun idx (k, e) -> e.Length)
let totalElements = elementsByFloor |> Array.sum
let mutable movements = 0
while elementsByFloor[3] <> totalElements do
let mutable currentFloor = 0
while elementsByFloor[currentFloor] = 0 do
currentFloor <- currentFloor + 1
movements <- movements + 2 * (elementsByFloor[currentFloor] - 1) - 1
elementsByFloor[currentFloor+1] <- elementsByFloor[currentFloor+1] + elementsByFloor[currentFloor]
elementsByFloor[currentFloor] <- 0
movements
let execute =
let path = "day11/day11_input.txt"
let content = LocalHelper.GetLinesFromFile path
let elementsbyfloor = parseContent content
let extralements =
[Generator("elerium"); Microchip("elerium"); Generator("dilithium"); Microchip("dilithium")]
let expandedElements =
elementsbyfloor
|> Array.map(fun (floor, elements) -> if floor = 0 then (floor, elements @ extralements) else (floor, elements))
moveElements expandedElements