-
Notifications
You must be signed in to change notification settings - Fork 0
/
Day10.cs
397 lines (367 loc) · 14.8 KB
/
Day10.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
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace AdventOfCode2016
{
class Day10 : Day
{
static int match1 = 61;
static int match2 = 17;
public dynamic Input
{
get
{
return @"bot 123 gives low to bot 191 and high to bot 162
bot 191 gives low to output 9 and high to bot 192
bot 182 gives low to bot 175 and high to bot 196
bot 113 gives low to bot 172 and high to bot 94
bot 78 gives low to bot 37 and high to bot 25
bot 187 gives low to bot 125 and high to bot 45
bot 71 gives low to bot 108 and high to bot 61
bot 154 gives low to bot 2 and high to bot 64
bot 142 gives low to bot 110 and high to bot 163
bot 109 gives low to output 0 and high to bot 43
bot 198 gives low to bot 101 and high to bot 52
bot 138 gives low to bot 9 and high to bot 47
value 5 goes to bot 189
bot 179 gives low to bot 176 and high to bot 14
bot 115 gives low to bot 82 and high to bot 181
bot 101 gives low to bot 90 and high to bot 5
bot 9 gives low to output 5 and high to bot 149
bot 181 gives low to bot 0 and high to bot 27
bot 119 gives low to bot 207 and high to bot 65
bot 202 gives low to bot 69 and high to bot 154
bot 100 gives low to bot 206 and high to bot 169
bot 72 gives low to bot 205 and high to bot 12
bot 146 gives low to bot 8 and high to bot 106
bot 58 gives low to bot 180 and high to bot 123
value 37 goes to bot 1
value 61 goes to bot 144
bot 205 gives low to bot 169 and high to bot 3
bot 91 gives low to bot 76 and high to bot 84
bot 93 gives low to bot 122 and high to bot 100
bot 76 gives low to bot 147 and high to bot 89
bot 102 gives low to bot 11 and high to bot 23
bot 43 gives low to output 11 and high to output 12
bot 128 gives low to bot 15 and high to bot 85
bot 137 gives low to bot 112 and high to bot 2
bot 88 gives low to bot 103 and high to bot 55
bot 162 gives low to bot 192 and high to bot 141
bot 183 gives low to bot 49 and high to bot 81
bot 127 gives low to bot 113 and high to bot 207
value 11 goes to bot 165
bot 28 gives low to bot 62 and high to bot 42
bot 95 gives low to bot 42 and high to bot 32
bot 50 gives low to bot 160 and high to bot 194
bot 68 gives low to bot 133 and high to bot 142
bot 20 gives low to bot 208 and high to bot 203
bot 178 gives low to bot 182 and high to bot 54
bot 120 gives low to bot 102 and high to bot 99
bot 131 gives low to bot 67 and high to bot 83
bot 21 gives low to bot 111 and high to bot 69
bot 27 gives low to bot 46 and high to bot 193
bot 98 gives low to bot 63 and high to bot 22
value 13 goes to bot 7
bot 121 gives low to bot 155 and high to bot 146
bot 41 gives low to bot 153 and high to bot 53
bot 75 gives low to bot 100 and high to bot 205
value 43 goes to bot 4
bot 206 gives low to bot 151 and high to bot 77
bot 0 gives low to bot 95 and high to bot 46
bot 208 gives low to output 14 and high to bot 126
bot 40 gives low to bot 187 and high to bot 184
bot 184 gives low to bot 45 and high to bot 124
bot 60 gives low to bot 188 and high to bot 202
value 67 goes to bot 198
bot 145 gives low to bot 22 and high to bot 108
bot 197 gives low to bot 195 and high to bot 190
bot 203 gives low to bot 126 and high to bot 51
bot 87 gives low to bot 51 and high to bot 179
bot 64 gives low to bot 128 and high to bot 85
bot 1 gives low to bot 198 and high to bot 173
bot 29 gives low to bot 71 and high to bot 168
bot 47 gives low to bot 149 and high to bot 113
bot 165 gives low to bot 80 and high to bot 135
bot 112 gives low to bot 162 and high to bot 174
bot 149 gives low to output 1 and high to bot 172
value 41 goes to bot 80
bot 5 gives low to bot 136 and high to bot 62
bot 143 gives low to bot 97 and high to bot 41
bot 86 gives low to bot 145 and high to bot 71
value 59 goes to bot 147
bot 57 gives low to bot 30 and high to bot 188
bot 36 gives low to bot 150 and high to bot 30
bot 135 gives low to bot 44 and high to bot 117
bot 134 gives low to bot 16 and high to bot 35
bot 167 gives low to bot 28 and high to bot 95
bot 22 gives low to bot 127 and high to bot 119
bot 26 gives low to bot 81 and high to bot 16
bot 33 gives low to bot 6 and high to bot 78
bot 171 gives low to bot 186 and high to bot 17
bot 16 gives low to bot 96 and high to bot 33
bot 118 gives low to bot 117 and high to bot 56
bot 199 gives low to bot 98 and high to bot 145
bot 188 gives low to bot 21 and high to bot 202
value 29 goes to bot 164
bot 169 gives low to bot 77 and high to bot 140
bot 96 gives low to bot 181 and high to bot 6
value 71 goes to bot 201
bot 194 gives low to bot 87 and high to bot 150
bot 160 gives low to bot 203 and high to bot 87
bot 15 gives low to bot 158 and high to bot 105
bot 42 gives low to bot 166 and high to bot 39
bot 133 gives low to bot 54 and high to bot 110
value 47 goes to bot 13
bot 31 gives low to output 8 and high to bot 9
bot 159 gives low to bot 74 and high to bot 155
bot 157 gives low to bot 12 and high to bot 187
bot 176 gives low to bot 139 and high to bot 58
bot 35 gives low to bot 33 and high to bot 78
bot 90 gives low to bot 148 and high to bot 136
bot 122 gives low to bot 70 and high to bot 206
bot 114 gives low to bot 72 and high to bot 157
bot 55 gives low to bot 40 and high to bot 184
bot 37 gives low to bot 193 and high to bot 25
value 31 goes to bot 13
bot 107 gives low to bot 99 and high to bot 93
bot 14 gives low to bot 58 and high to bot 38
bot 77 gives low to bot 86 and high to bot 29
bot 116 gives low to bot 79 and high to bot 170
bot 23 gives low to bot 132 and high to bot 70
bot 148 gives low to bot 144 and high to bot 120
bot 195 gives low to bot 170 and high to bot 185
bot 185 gives low to bot 138 and high to bot 63
bot 62 gives low to bot 107 and high to bot 166
bot 174 gives low to bot 141 and high to bot 128
bot 7 gives low to bot 91 and high to bot 11
bot 3 gives low to bot 140 and high to bot 34
bot 12 gives low to bot 3 and high to bot 125
value 7 goes to bot 148
bot 70 gives low to bot 161 and high to bot 151
bot 89 gives low to bot 116 and high to bot 195
bot 108 gives low to bot 119 and high to bot 204
bot 201 gives low to bot 1 and high to bot 104
bot 18 gives low to output 15 and high to bot 208
bot 66 gives low to bot 177 and high to bot 130
bot 189 gives low to bot 165 and high to bot 177
bot 48 gives low to output 13 and high to bot 18
bot 186 gives low to bot 189 and high to bot 66
bot 82 gives low to bot 167 and high to bot 0
bot 92 gives low to bot 201 and high to bot 49
bot 144 gives low to bot 7 and high to bot 102
bot 97 gives low to bot 146 and high to bot 153
bot 104 gives low to bot 173 and high to bot 82
bot 74 gives low to bot 83 and high to bot 50
bot 49 gives low to bot 104 and high to bot 115
bot 172 gives low to output 20 and high to bot 48
bot 163 gives low to bot 41 and high to bot 53
bot 117 gives low to bot 26 and high to bot 134
bot 168 gives low to bot 61 and high to bot 182
bot 65 gives low to bot 131 and high to bot 74
bot 180 gives low to output 6 and high to bot 191
bot 126 gives low to output 19 and high to bot 19
value 19 goes to bot 186
bot 166 gives low to bot 93 and high to bot 75
bot 193 gives low to bot 59 and high to bot 88
bot 81 gives low to bot 115 and high to bot 96
bot 207 gives low to bot 94 and high to bot 131
bot 130 gives low to bot 118 and high to bot 56
bot 153 gives low to bot 106 and high to bot 152
value 17 goes to bot 92
bot 110 gives low to bot 143 and high to bot 163
bot 192 gives low to output 7 and high to bot 129
bot 156 gives low to bot 10 and high to bot 68
bot 83 gives low to bot 20 and high to bot 160
bot 2 gives low to bot 174 and high to bot 64
value 23 goes to bot 91
bot 10 gives low to bot 178 and high to bot 133
bot 103 gives low to bot 157 and high to bot 40
bot 61 gives low to bot 204 and high to bot 175
bot 63 gives low to bot 47 and high to bot 127
bot 105 gives low to bot 200 and high to bot 24
bot 79 gives low to output 10 and high to bot 31
bot 73 gives low to bot 168 and high to bot 178
bot 19 gives low to output 2 and high to bot 139
bot 125 gives low to bot 34 and high to bot 156
bot 56 gives low to bot 134 and high to bot 35
bot 44 gives low to bot 183 and high to bot 26
bot 4 gives low to output 3 and high to bot 79
bot 155 gives low to bot 50 and high to bot 8
value 73 goes to bot 101
bot 38 gives low to bot 123 and high to bot 112
bot 151 gives low to bot 199 and high to bot 86
bot 17 gives low to bot 66 and high to bot 130
bot 13 gives low to bot 171 and high to bot 17
bot 190 gives low to bot 185 and high to bot 98
bot 161 gives low to bot 190 and high to bot 199
bot 139 gives low to output 16 and high to bot 180
bot 99 gives low to bot 23 and high to bot 122
bot 53 gives low to bot 152 and high to bot 60
bot 94 gives low to bot 48 and high to bot 67
bot 132 gives low to bot 197 and high to bot 161
bot 150 gives low to bot 179 and high to bot 209
bot 173 gives low to bot 52 and high to bot 167
bot 45 gives low to bot 156 and high to bot 124
bot 30 gives low to bot 209 and high to bot 21
bot 67 gives low to bot 18 and high to bot 20
bot 84 gives low to bot 89 and high to bot 197
bot 8 gives low to bot 194 and high to bot 36
bot 59 gives low to bot 114 and high to bot 103
bot 209 gives low to bot 14 and high to bot 111
value 53 goes to bot 76
bot 69 gives low to bot 137 and high to bot 154
bot 46 gives low to bot 32 and high to bot 59
bot 111 gives low to bot 38 and high to bot 137
bot 196 gives low to bot 121 and high to bot 97
bot 52 gives low to bot 5 and high to bot 28
bot 11 gives low to bot 84 and high to bot 132
bot 204 gives low to bot 65 and high to bot 159
bot 164 gives low to bot 92 and high to bot 183
bot 24 gives low to bot 109 and high to bot 43
value 2 goes to bot 171
bot 51 gives low to bot 19 and high to bot 176
bot 136 gives low to bot 120 and high to bot 107
bot 147 gives low to bot 4 and high to bot 116
bot 25 gives low to bot 88 and high to bot 55
bot 129 gives low to output 18 and high to bot 158
bot 152 gives low to bot 57 and high to bot 60
bot 39 gives low to bot 75 and high to bot 72
bot 124 gives low to bot 68 and high to bot 142
bot 141 gives low to bot 129 and high to bot 15
bot 85 gives low to bot 105 and high to bot 24
value 3 goes to bot 90
bot 80 gives low to bot 164 and high to bot 44
bot 54 gives low to bot 196 and high to bot 143
bot 34 gives low to bot 73 and high to bot 10
bot 175 gives low to bot 159 and high to bot 121
bot 32 gives low to bot 39 and high to bot 114
bot 140 gives low to bot 29 and high to bot 73
bot 200 gives low to output 17 and high to bot 109
bot 106 gives low to bot 36 and high to bot 57
bot 177 gives low to bot 135 and high to bot 118
bot 170 gives low to bot 31 and high to bot 138
bot 158 gives low to output 4 and high to bot 200
bot 6 gives low to bot 27 and high to bot 37";
}
}
public string Part1(dynamic input)
{
match1 = 61;
match2 = 17;
return RunBots(input);
}
private string RunBots(dynamic input)
{
outputs.Clear();
try
{
foreach (var instruction in Utils.splitLines((string)input).OrderBy(i => i))
{
var parts = instruction.Split(' ');
if (parts[0] == "bot")
{
GetOutput(parts[0] + parts[1]).Init(parts[1], GetOutput(parts[5] + parts[6]), GetOutput(parts[10] + parts[11]));
}
else
{
GetOutput(parts[4] + parts[5]).AddValue(int.Parse(parts[1]));
}
}
}
catch (FinishedException e)
{
return e.MatchingBot.ToString();
}
return "";
}
public string Part2(dynamic input)
{
match1 = -1;
match2 = -1;
RunBots(input);
return (GetOutput("output0").Value * GetOutput("output1").Value * GetOutput("output2").Value).ToString();
}
public void Test()
{
match1 = 3;
match2 = 5;
Utils.Test(RunBots, new []
{
@"value 5 goes to bot 2
bot 2 gives low to bot 1 and high to bot 0
value 3 goes to bot 1
bot 1 gives low to output 1 and high to bot 0
bot 0 gives low to output 2 and high to output 0
value 2 goes to bot 2"
}, new string[] { "0" }
);
}
private static Dictionary<string, IOutput> outputs = new Dictionary<string, IOutput>();
private static IOutput GetOutput(string id)
{
if (!outputs.ContainsKey(id))
{
outputs[id] = id.StartsWith("bot") ? (IOutput)new Bot() : new Output();
}
return outputs[id];
}
private class Bot : IOutput
{
public IOutput low;
public IOutput high;
int? value1;
public string id;
public void AddValue(int value)
{
if (value1.HasValue)
{
if ((value1.Value == match1 && value == match2) || (value1.Value == match2 && value == match1))
{
throw new FinishedException() { MatchingBot = id };
}
low.AddValue(Math.Min(value, value1.Value));
high.AddValue(Math.Max(value, value1.Value));
}
else
{
value1 = value;
}
}
public void Init(string id, IOutput low, IOutput high)
{
if (this.id != null)
{
throw new InvalidOperationException();
}
this.id = id;
this.low = low;
this.high = high;
}
public int Value { get { throw new NotImplementedException(); } }
}
private class Output :IOutput
{
public int Value { get; private set; }
public void AddValue(int value)
{
this.Value = value;
}
public void Init(string id, IOutput low, IOutput high)
{
throw new NotImplementedException();
}
}
private interface IOutput
{
void AddValue(int value);
void Init(string id, IOutput low, IOutput high);
int Value { get; }
}
public class FinishedException : Exception
{
public string MatchingBot;
}
}
}