aoc2019/Day4.cs

50 lines
1.2 KiB
C#
Raw Normal View History

2019-12-12 04:54:07 +00:00
using System.Linq;
2019-12-04 16:32:43 +00:00
namespace aoc2019
{
internal class Day4 : Day
{
2019-12-05 06:19:39 +00:00
public override int DayNumber => 4;
private readonly int start;
private readonly int end;
2019-12-04 16:32:43 +00:00
public Day4()
{
var range = Input.First().Split('-').Select(int.Parse).ToList();
2019-12-04 16:32:43 +00:00
start = range[0]; end = range[1];
}
private bool IsValid(int i)
{
2019-12-04 18:42:35 +00:00
int prev = 0; bool hasDup = false;
2019-12-04 16:32:43 +00:00
foreach (var c in i.ToString())
{
int curr = c - '0';
2019-12-04 18:42:35 +00:00
if (curr < prev) return false;
if (curr == prev) hasDup = true;
2019-12-04 16:32:43 +00:00
prev = curr;
}
2019-12-04 18:42:35 +00:00
return i >= start && i <= end && hasDup;
2019-12-04 16:32:43 +00:00
}
2019-12-04 18:42:35 +00:00
private bool HasOnePair(int i)
2019-12-04 16:32:43 +00:00
{
2019-12-04 18:42:35 +00:00
var s = i.ToString();
2019-12-05 06:19:39 +00:00
return IsValid(i) && s.Select(c => s.Count(j => j == c)).Any(c => c == 2);
2019-12-04 16:32:43 +00:00
}
2019-12-05 06:44:55 +00:00
public override string Part1()
{
return $"{Enumerable.Range(start, end).Count(IsValid)}";
}
2019-12-05 06:19:39 +00:00
public override string Part2()
2019-12-04 16:32:43 +00:00
{
2019-12-05 06:44:55 +00:00
return $"{Enumerable.Range(start, end).Count(HasOnePair)}";
2019-12-04 16:32:43 +00:00
}
}
}
2019-12-04 18:42:35 +00:00