AdventOfCode2022/AOC2022/Puzzles/Day3.cs

90 lines
1.9 KiB
C#

namespace AOC2022.Puzzles;
internal class Day3 : IPuzzle
{
private readonly string[] _linesFromFile;
private readonly int noOfRuckSacks;
private string[] _leftComparments;
private string[] _rightCompartments;
public Day3(string[] linesFromFile)
{
_linesFromFile = linesFromFile;
noOfRuckSacks = linesFromFile.Length;
SplitRuckSacks();
}
private void SplitRuckSacks()
{
_leftComparments = new string[noOfRuckSacks];
_rightCompartments = new string[noOfRuckSacks];
var index = 0;
foreach (var line in _linesFromFile)
{
var ruckSack = line.Trim();
var left = ruckSack[..(ruckSack.Length / 2)];
var right = ruckSack[(ruckSack.Length / 2)..];
_leftComparments[index] = left;
_rightCompartments[index] = right;
index++;
}
}
public void FirstPuzzle()
{
var prioritySum = 0;
for (int i = 0; i < noOfRuckSacks; i++)
{
char duplicateItem = ' ';
foreach (var item in _leftComparments[i])
{
if (_rightCompartments[i].Contains(item))
{
duplicateItem = item;
break;
}
}
prioritySum += EvaluatePriority(duplicateItem);
}
Console.WriteLine(prioritySum.ToString());
}
public void SecondPuzzle()
{
var prioritySum = 0;
for (int i = 0; i < noOfRuckSacks; i += 3)
{
var elf1Sack = _linesFromFile[i].Trim();
var elf2Sack = _linesFromFile[i + 1].Trim();
var elf3Sack = _linesFromFile[i + 2].Trim();
char authenticItem = ' ';
foreach (var item in elf1Sack)
{
if (elf2Sack.Contains(item) && elf3Sack.Contains(item))
{
authenticItem = item;
break;
}
}
prioritySum += EvaluatePriority(authenticItem);
}
Console.WriteLine(prioritySum.ToString());
}
private static int EvaluatePriority(char ruckSackItem)
{
if (char.IsUpper(ruckSackItem))
{
return (ruckSackItem - 'A') + 27;
}
else if (char.IsLower(ruckSackItem))
{
return (ruckSackItem - 'a') + 1;
}
else
{
return 0;
}
}
}