-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathDay05.cs
82 lines (72 loc) · 2.17 KB
/
Day05.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
namespace advent_of_code_csharp_2024;
public class Day05
{
public static IDictionary<int, List<int>> ParseRules(IEnumerable<string> lines)
{
return lines
.Select(line =>
{
var parts = line.Split('|');
return (int.Parse(parts[0]), int.Parse(parts[1]));
})
.GroupBy(x => x.Item1)
.ToDictionary(x => x.Key, x => x.Select(y => y.Item2).ToList());
}
public static IEnumerable<List<int>> ParseUpdate(IEnumerable<string> lines)
{
return lines
.Select(line =>
{
return line
.Split(",")
.Select(text => int.Parse(text))
.ToList();
});
}
public static (IEnumerable<string>, IEnumerable<string>) SplitInput(IEnumerable<string> lines)
{
var pageOrderingRules = lines.Where(line => line.Contains('|'));
var pageNumbersUpdates = lines.Where(line => line.Contains(','));
return (pageOrderingRules, pageNumbersUpdates);
}
public static bool IsRuleOk(List<int> numberRules, List<int> remainingPages)
{
return remainingPages.All(numberRules.Contains);
}
public static bool IsUpdateValid(List<int> update, IDictionary<int, List<int>> rules)
{
for (int i = 1; i < update.Count; i++)
{
var currentPageNumber = update[i];
if (rules.TryGetValue(currentPageNumber, out List<int>? currentPageRules))
{
var previousPages = update.Take(i).ToList();
if (previousPages.Any(previousPage => currentPageRules.Contains(previousPage)))
{
return false;
}
}
}
return true;
}
public static int ToUpdateValue(List<int> update, IDictionary<int, List<int>> rules)
{
if (IsUpdateValid(update, rules))
{
return update[update.Count / 2];
}
else
{
return 0;
}
}
public static int Solver(IEnumerable<string> lines)
{
var (pageOrderingRules, pageNumbersUpdates) = SplitInput(lines);
var rules = ParseRules(pageOrderingRules);
var updates = ParseUpdate(pageNumbersUpdates).ToList();
return updates
.Select(update => ToUpdateValue(update, rules))
.Sum();
}
}