about summary refs log tree commit diff
path: root/aoc2019/Day04.cs
blob: 808eb649ad8f17734de07da0867da47a5e792f3b (plain) (blame)
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
using System.Linq;

namespace aoc2019
{
    public sealed class Day04 : Day
    {
        private readonly int end;

        private readonly int start;

        public Day04() : base(4, "Secure Container")
        {
            var range = Input.First().Split('-').Select(int.Parse).ToList();
            start = range[0];
            end = range[1];
        }

        private bool IsValid(int i)
        {
            var prev = 0;
            var hasDup = false;
            foreach (var c in i.ToString())
            {
                var curr = c - '0';
                if (curr < prev) return false;
                if (curr == prev) hasDup = true;
                prev = curr;
            }

            return i >= start && i <= end && hasDup;
        }

        private bool HasOnePair(int i)
        {
            var s = i.ToString();
            return IsValid(i) && s.Select(c => s.Count(j => j == c)).Any(c => c == 2);
        }

        public override string Part1()
        {
            return $"{Enumerable.Range(start, end).Count(IsValid)}";
        }

        public override string Part2()
        {
            return $"{Enumerable.Range(start, end).Count(HasOnePair)}";
        }
    }
}