summaryrefslogtreecommitdiffstats
path: root/day17/day17-1.js
blob: 42e6b6f63a03140427b22035fcf6c015af39a9a1 (plain) (blame)
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
const data = require('./data')
const startArray = [data.split(/\n/g).filter(e => e).map(e => e.split(''))]
const cycle = (arr) => {
  const l = arr[0].length
  const empty = Array(l+2).fill(Array(l+2).fill('.'))
  const empty2 = Array(l+2).fill('.')
  const addDots = ars => ars.map(ar => ([empty2, ...(ar.map(a => ['.', ...a, '.'])), empty2]))
  const resized = [empty, ...addDots(arr), empty]
  const around = (iz, iy, ix) => {
    const f = (rz, ry, rx) => {
      if (
        !resized[iz+rz]
        || !resized[iz+rz][iy+ry] 
        || !resized[iz+rz][iy+ry][ix+rx]
      ) { return 0 }
      return resized[iz+rz][iy+ry][ix+rx] === '#' ? 1 : 0
    }

    let c = 0
    for (let z=-1; z<=1; z++) {
      for (let y=-1; y<=1; y++) {
        for (let x=-1; x<=1; x++) {
          if(!(x == 0 && y == 0 && z == 0)) { c += f(z, y, x) }
        }
      }
    }
    return c
  }

  return resized.map((z, iz) => z.map((y,iy) => y.map((x,ix) => {
    const active = x === '#'
    const activeAround = around(iz,iy,ix)

    if (active) {
      return (activeAround === 2 || activeAround === 3) ? '#' : '.'
    } else {
      return (activeAround === 3) ? '#' : '.'
    }
  })))
}

let cycleResult = startArray, round = 1
while (round <= 6) {
 cycleResult = cycle(cycleResult)
 round++
}

let result = 0
cycleResult.forEach(z => z.forEach(y => y.forEach(x => {
  if (x === '#') {result++}
})))

console.log('Answer: ', result)