about summary refs log tree commit diff
path: root/aoc2019/Day23.cs
blob: 29da6a7944472784e23791a3638730ed1a02af34 (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
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
namespace aoc2019;

public sealed class Day23 : Day
{
    public Day23() : base(23, "Category Six")
    {
    }

    public override string Part1()
    {
        var vms = Enumerable.Range(0, 50)
            .Select((s, i) =>
            {
                var vm = new IntCodeVM(Input.First());
                vm.Run(i);
                return vm;
            }).ToList();

        while (true)
            foreach (var vm in vms)
            {
                while (vm.output.Count > 0)
                {
                    var destination = (int)vm.Result;
                    var x = vm.Result;
                    var y = vm.Result;

                    if (destination == 255) return $"{y}";

                    vms[destination].Run(x, y);
                }

                vm.Run(-1);
            }
    }

    public override string Part2()
    {
        var vms = Enumerable.Range(0, 50)
            .Select((s, i) =>
            {
                var vm = new IntCodeVM(Input.First());
                vm.Run(i);
                return vm;
            }).ToList();

        long natX = 0, natY = 0, lastYSent = -1;

        while (true)
        {
            var numIdle = 0;
            foreach (var vm in vms)
            {
                var isIdle = true;
                while (vm.output.Count > 0)
                {
                    var destination = (int)vm.Result;
                    var x = vm.Result;
                    var y = vm.Result;

                    if (destination == 255)
                    {
                        natX = x;
                        natY = y;
                    }
                    else
                    {
                        vms[destination].Run(x, y);
                    }

                    isIdle = false;
                }

                vm.Run(-1);
                if (isIdle) numIdle++;
            }

            if (numIdle == 50)
            {
                if (natY == lastYSent) return $"{natY}";
                vms[0].Run(natX, natY);
                lastYSent = natY;
            }
        }
    }
}