-
Notifications
You must be signed in to change notification settings - Fork 10
/
Copy pathDay14.cs
95 lines (78 loc) · 2.99 KB
/
Day14.cs
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
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
using AdventOfCode.CSharp.Common;
using System;
using System.Collections.Generic;
namespace AdventOfCode.CSharp.Y2015.Solvers;
public class Day14 : ISolver
{
public record Reindeer(int Speed, int FlyDuration, int RestDuration);
public class ReindeerState(Reindeer data)
{
public Reindeer Data { get; init; } = data;
public int DistanceTraveled { get; set; } = 0;
public int Points { get; set; } = 0;
public int DurationLeft { get; set; } = data.FlyDuration;
public bool IsFlying { get; set; } = true;
}
public static void Solve(ReadOnlySpan<byte> input, Solution solution)
{
var reindeers = new List<Reindeer>();
foreach (Range lineRange in input.SplitLines())
{
reindeers.Add(ParseLine(input[lineRange]));
}
var reindeerStates = new ReindeerState[reindeers.Count];
for (int i = 0; i < reindeerStates.Length; i++)
{
reindeerStates[i] = new ReindeerState(reindeers[i]);
}
for (int i = 0; i < 2503; i++)
{
int furthestDistance = 0;
for (int j = 0; j < reindeerStates.Length; j++)
{
ReindeerState reindeerState = reindeerStates[j];
if (reindeerState.IsFlying)
{
reindeerState.DistanceTraveled += reindeerState.Data.Speed;
}
int durationLeft = --reindeerState.DurationLeft;
if (durationLeft == 0)
{
reindeerState.IsFlying = !reindeerState.IsFlying;
reindeerState.DurationLeft = reindeerState.IsFlying
? reindeerState.Data.FlyDuration
: reindeerState.Data.RestDuration;
}
furthestDistance = Math.Max(reindeerState.DistanceTraveled, furthestDistance);
}
foreach (ReindeerState state in reindeerStates)
{
if (state.DistanceTraveled == furthestDistance)
{
state.Points++;
}
}
}
int maxDistance = 0;
int maxPoints = 0;
foreach (ReindeerState state in reindeerStates)
{
maxDistance = Math.Max(state.DistanceTraveled, maxDistance);
maxPoints = Math.Max(state.Points, maxPoints);
}
solution.SubmitPart1(maxDistance);
solution.SubmitPart2(maxPoints);
}
private static Reindeer ParseLine(ReadOnlySpan<byte> line)
{
var reader = new SpanReader(line);
reader.SkipUntil(' ');
reader.SkipLength("can fly ".Length);
int speed = reader.ReadPosIntUntil(' ');
reader.SkipLength("km/s for ".Length);
int flyDuration = reader.ReadPosIntUntil(' ');
reader.SkipLength("seconds, but then must rest for ".Length);
int restDuration = reader.ReadPosIntUntil(' ');
return new Reindeer(speed, flyDuration, restDuration);
}
}