-
Notifications
You must be signed in to change notification settings - Fork 0
/
part2.ts
35 lines (29 loc) · 1.03 KB
/
part2.ts
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
import * as fs from 'fs';
const input = fs.readFileSync('input', 'utf8');
const monkeys = input.split('\n\n').map((monkey) => {
const lines = monkey.split('\n');
const [, items] = lines[1].split(': ');
const [safe] = lines[2].match(/(old|\d+) (\*|\+) (old|\d+)$/);
return {
items: items.split(', ').map((x) => +x),
operation: new Function('old', `return ${safe}`),
divisible: Number(lines[3].match(/\d+$/)[0]),
yes: Number(lines[4].match(/\d+$/)[0]),
no: Number(lines[5].match(/\d+$/)[0]),
business: 0,
};
});
const worryDivisor = monkeys.reduce((prev, monkey) => prev * monkey.divisible, 1);
for (let i = 0; i < 10000; i++) {
for (const monkey of monkeys) {
while (monkey.items.length > 0) {
let worry = monkey.operation(monkey.items.shift());
worry %= worryDivisor;
const target = worry % monkey.divisible === 0 ? monkey.yes : monkey.no;
monkeys[target].items.push(worry);
monkey.business++;
}
}
}
const [top1, top2] = monkeys.sort((a, b) => b.business - a.business);
console.log(top1.business * top2.business);