-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathDay05.cs
More file actions
104 lines (91 loc) · 3.02 KB
/
Day05.cs
File metadata and controls
104 lines (91 loc) · 3.02 KB
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
96
97
98
99
100
101
102
103
104
using System.Collections.Immutable;
using System.Linq.Expressions;
using _2024.Utils;
namespace _2024._05;
public class Day05 : Base
{
public Day05(bool example) : base(example)
{
Day = "5";
}
private int ReadRules(string[] input, out List<ValueTuple<int, int>> rules)
{
rules = [];
foreach (var (line, idx) in input.Enumerate())
{
if (string.IsNullOrEmpty(line))
{
return idx+1;
}
string[] numbers = line.Split("|");
rules.Add((int.Parse(numbers[0]), int.Parse(numbers[1])));
}
return -1;
}
private bool IsUpdateCorrect(string[] update, List<ValueTuple<int, int>> rules)
{
HashSet<int> seenNumbers = [];
int[] updateNumbers = new int[update.Length];
for (int i = 0; i < update.Length; i++)
{
updateNumbers[i] = int.Parse(update[i]);
}
foreach (var (number, idx) in updateNumbers.Enumerate())
{
seenNumbers.Add(number);
var numberSecondRules = rules.Where(x => x.Item2 == number);
foreach (var (first, second) in numberSecondRules)
{
if (updateNumbers.Any(x => x == first) && !seenNumbers.Contains(first))
{
return false;
}
}
}
return true;
}
private static int SortByRules(int x, int y, List<ValueTuple<int, int>> rules)
{
var necessaryRules = rules.FirstOrDefault(rule => rule.Item1 == y && rule.Item2 == x);
if (necessaryRules == default)
{
return -1;
}
return 1;
}
public override object PartOne()
{
string[] input = ReadInput();
int middleNumbersSum = 0;
int updatesStart = ReadRules(input, out List<(int, int)> orderRules);
for (int i = updatesStart; i < input.Length; i++)
{
string[] line = input[i].Split(",");
if (IsUpdateCorrect(line, orderRules))
{
middleNumbersSum += int.Parse(line[line.Length / 2]);
}
}
return middleNumbersSum;
}
public override object PartTwo()
{
string[] input = ReadInput();
int middleNumbersSum = 0;
int updatesStart = ReadRules(input, out List<(int, int)> orderRules);
for (int i = updatesStart; i < input.Length; i++)
{
string[] line = input[i].Split(",");
if (IsUpdateCorrect(line, orderRules))
{
continue;
}
List<int> numbers = line
.Select(int.Parse)
.OrderBy(x => x, Comparer<int>.Create((x, y) => SortByRules(x, y, orderRules)))
.ToList();
middleNumbersSum += numbers[numbers.Count / 2];
}
return middleNumbersSum;
}
}