-
Notifications
You must be signed in to change notification settings - Fork 10
/
Day23.cs
96 lines (85 loc) · 3.22 KB
/
Day23.cs
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
87
88
89
90
91
92
93
94
95
96
using AdventOfCode.CSharp.Common;
using System;
using System.Collections.Generic;
namespace AdventOfCode.CSharp.Y2015.Solvers;
public class Day23 : ISolver
{
public enum InstructionType
{
Half,
Triple,
Increment,
Jump,
JumpIfEven,
JumpIfOne
}
public record Instruction(InstructionType Type, int Arg1, int Arg2 = 0);
public static void Solve(ReadOnlySpan<byte> input, Solution solution)
{
var instructions = new List<Instruction>();
foreach (Range lineRange in input.SplitLines())
{
ReadOnlySpan<byte> line = input[lineRange];
static int ParseReg(ReadOnlySpan<byte> line) => line[4] == 'a' ? 0 : 1;
static int ParseNumber(ReadOnlySpan<byte> str)
{
int mul = str[0] == '+' ? 1 : -1;
int c = str[1] - '0';
for (int i = 2; i < str.Length; i++)
c = c * 10 + str[i] - '0';
return mul * c;
}
Instruction instruction = line[2] switch
{
(byte)'f' => new Instruction(InstructionType.Half, ParseReg(line)),
(byte)'l' => new Instruction(InstructionType.Triple, ParseReg(line)),
(byte)'c' => new Instruction(InstructionType.Increment, ParseReg(line)),
(byte)'p' => new Instruction(InstructionType.Jump, -1, ParseNumber(line[4..])),
(byte)'e' => new Instruction(InstructionType.JumpIfEven, ParseReg(line), ParseNumber(line[7..])),
(byte)'o' => new Instruction(InstructionType.JumpIfOne, ParseReg(line), ParseNumber(line[7..])),
_ => default!
};
instructions.Add(instruction);
}
Instruction[] instructionArr = [.. instructions];
int part1 = Simulate(instructionArr, 0);
int part2 = Simulate(instructionArr, 1);
solution.SubmitPart1(part1);
solution.SubmitPart2(part2);
}
private static int Simulate(Instruction[] instructions, int aStart)
{
int[] variables = new int[2];
variables[0] = aStart;
int i = 0;
while (i >= 0 && i < instructions.Length)
{
Instruction instruction = instructions[i];
switch (instruction.Type)
{
case InstructionType.Half:
variables[instruction.Arg1] /= 2;
i++;
break;
case InstructionType.Triple:
variables[instruction.Arg1] *= 3;
i++;
break;
case InstructionType.Increment:
variables[instruction.Arg1]++;
i++;
break;
case InstructionType.Jump:
i += instruction.Arg2;
break;
case InstructionType.JumpIfEven:
i += variables[instruction.Arg1] % 2 == 0 ? instruction.Arg2 : 1;
break;
case InstructionType.JumpIfOne:
i += variables[instruction.Arg1] == 1 ? instruction.Arg2 : 1;
break;
}
}
return variables[1];
}
}