2018 d4 p1 js
This commit is contained in:
parent
fef7786f8c
commit
634b22067f
1134
2018/4/input.txt
Normal file
1134
2018/4/input.txt
Normal file
File diff suppressed because it is too large
Load diff
43
2018/4/part1.js
Normal file
43
2018/4/part1.js
Normal file
|
@ -0,0 +1,43 @@
|
|||
const fs = require('fs');
|
||||
|
||||
let input = fs.readFileSync('input.txt', 'utf-8').split('\n').sort((a, b) => val(a).getTime() - val(b).getTime());
|
||||
|
||||
function val(a) {
|
||||
let time = new Date(a.match(/\[(.*)\]/)[1]);
|
||||
return time;
|
||||
}
|
||||
|
||||
let guards = {};
|
||||
let id;
|
||||
let start;
|
||||
let shifts = []
|
||||
for (let line of input) {
|
||||
let match = line.match(/#(\d+)/);
|
||||
if (match) {
|
||||
id = match[1];
|
||||
if (!guards[id])
|
||||
guards[id] = {};
|
||||
shifts.push(id);
|
||||
} else {
|
||||
if (line.includes('falls')) {
|
||||
start = val(line).getMinutes();
|
||||
} else if (line.includes('wakes')) {
|
||||
let end = val(line).getMinutes();
|
||||
for (time = start; time < end; time++) {
|
||||
guards[id][time] = (guards[id][time] || 0) + 1;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
function sleps(guard) {
|
||||
try {
|
||||
return Object.values(guard[1]).reduce((a, b) => a + b) / shifts.filter(v => v == guard[0]).length;
|
||||
} catch (err) {
|
||||
return 0;
|
||||
}
|
||||
}
|
||||
id = Object.entries(guards).sort((a, b) => sleps(b) - sleps(a))[0][0];
|
||||
let minute = Number(Object.entries(guards[id]).sort((a, b) => b[1] - a[1])[0][0]);
|
||||
|
||||
console.log(`#${id} * minute ${minute} = ${id * minute}`)
|
|
@ -1,6 +1,6 @@
|
|||
# Advent of Code Solutions
|
||||
|
||||
It\'s a fun challenge from [here](https://adventofcode.com).
|
||||
It's a fun challenge from [here](https://adventofcode.com).
|
||||
|
||||
# Completed Challenges
|
||||
|
||||
|
@ -15,6 +15,7 @@ It\'s a fun challenge from [here](https://adventofcode.com).
|
|||
* [1](https://adventofcode.com/2018/day/1) js * *
|
||||
* [2](https://adventofcode.com/2018/day/2) py * *
|
||||
* [3](https://adventofcode.com/2018/day/3) js * *
|
||||
* [4](https://adventofcode.com/2018/day/4) js *
|
||||
|
||||
# Languages Used
|
||||
* Python
|
||||
|
|
Loading…
Reference in a new issue