ben
/
aoc
1
0
Fork 0
aoc/AOC2021/Day03.cs

61 lines
1.6 KiB
C#

namespace AOC2021;
/// <summary>
/// Day 3: <a href="https://adventofcode.com/2021/day/3"/>
/// </summary>
public sealed class Day03() : Day(2021, 3, "Binary Diagnostic")
{
private List<string>? _report;
public override void ProcessInput() =>
_report = Input.ToList();
public override object Part1()
{
var l = _report!.Count / 2;
var g = new StringBuilder();
var e = new StringBuilder();
foreach (var i in Enumerable.Range(0, _report[0].Length))
{
var ones = _report.Select(r => r[i]).Count(c => c == '1');
g.Append(ones > l ? '1' : '0');
e.Append(ones > l ? '0' : '1');
}
var gamma = g.ToString().BigIntegerFromBinaryString();
var epsilon = e.ToString().BigIntegerFromBinaryString();
return gamma * epsilon;
}
public override object Part2()
{
var o = _report!;
var c = _report!;
var i = 0;
while (o.Count > 1)
{
var most = MostCommon(i, o);
o = o.Where(r => r[i] == most).ToList();
i++;
}
var o2 = o.Single().BigIntegerFromBinaryString();
i = 0;
while (c.Count > 1)
{
var most = MostCommon(i, c);
c = c.Where(r => r[i] != most).ToList();
i++;
}
var co2 = c.Single().BigIntegerFromBinaryString();
return o2 * co2;
char MostCommon(int index, IReadOnlyCollection<string> report) =>
report.Count(r => r[index] == '1') >= report.Count / 2.0 ? '1' : '0';
}
}