-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathday16.js
85 lines (81 loc) · 2.21 KB
/
day16.js
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
const fs = require('fs')
const infile = fs.readFileSync('input/day16', 'utf-8')
function day161(input){
input = input.split(/\r\n.*tickets?:\r\n/g)
let requirements = input[0].split('\r\n')
requirements.pop()
requirements = requirements.map(e=>e.split(': ')[1].split(/-| or /gm).map(f=>parseInt(f)))
let tickets = input[2].split('\r\n').map(e=>e.split(',').map(f=>parseInt(f)))
tickets.forEach((e,i)=>{
let validFields = 0
e.forEach((f,j)=>{
for(let k=0;k<requirements.length;k++){
if(requirements[k][0]<=f&&f<=requirements[k][1]||requirements[k][2]<=f&&f<=requirements[k][3]){
tickets[i][j]=0;
break;
}
}
})
})
return tickets.flat().reduce((p,c)=>p+c)
}
function day162(input){
input = input.split(/\r\n.*tickets?:\r\n/g)
let reqs = input[0].split('\r\n')
reqs.pop()
let requirements = reqs.map(e=>e.split(': ')[1].split(/-| or /gm).map(f=>parseInt(f)))
let tickets = input[2].split('\r\n').map(e=>e.split(',').map(f=>parseInt(f)))
let validTickets = []
tickets.forEach((e,i)=>{
let validFields = 0
e.forEach((f,j)=>{
for(let k=0;k<requirements.length;k++){
if(requirements[k][0]<=f&&f<=requirements[k][1]||requirements[k][2]<=f&&f<=requirements[k][3]){
validFields++
break;
}
}
})
if(validFields == requirements.length){
validTickets.push(tickets[i])
}
})
let fieldValues = []
reqs.map(e=>fieldValues.push([]))
validTickets.forEach(e=>{
e.forEach((f,i)=>{
fieldValues[i].push(f)
})
})
let fieldCandidates = []
reqs.map((e,i)=>fieldCandidates.push([i]))
fieldValues.forEach((e,i)=>{
requirements.forEach((f,j)=>{
let c =0
e.forEach(g=>{
if(f[0]<=g&&g<=f[1]||f[2]<=g&&g<=f[3]) c++
})
if(c==e.length){
let req = reqs[j]
req = req.split(':')[0]
fieldCandidates[i].push(req)
}
})
})
fieldCandidates.sort((a,b)=>a.length-b.length)
let fieldMap = new Map()
fieldCandidates.forEach((e,i)=>{
e.slice(1).forEach(f=>{
if(!fieldMap.has(f)) fieldMap.set(f, e[0])
})
})
let myTicket = input[1]
myTicket = myTicket.split(',').map(e=>parseInt(e))
let product = 1;
fieldMap.forEach((v,k)=>{
if(k.startsWith('departure')) product *= myTicket[v]
})
return product
}
console.log(day161(infile))
console.log(day162(infile))