aboutsummaryrefslogtreecommitdiff
path: root/src/2020/day5/aoc.h
blob: d43479095e108b47ab8c0321186405937fb021eb (plain)
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
#pragma once

#include "common.h"

namespace aoc2020 {

struct seat {
  enum {
    rows = 128,
    cols = 8,
  };

  int row;
  int col;

  int id() const noexcept { return row * 8 + col; }
  bool operator<(const seat& other) const noexcept { return id() < other.id(); }

  seat(int r, int c) : row(r), col(c) {}

  // F lower
  // B higher
  // L lower
  // R higher
  seat(line_view lv) {
    const char* p = lv.line;
    int minr = 0;
    int maxr = 128;
    int minc = 0;
    int maxc = 8;
    while (p < lv.line + lv.length) {
      int midr = (maxr + minr) / 2;
      if (*p == 'F') {
        maxr = midr;
      }
      if (*p == 'B') {
        minr = midr;
      }
      int midc = (maxc + minc) / 2;
      if (*p == 'L') {
        maxc = midc;
      }
      if (*p == 'R') {
        minc = midc;
      }
      p++;
    }
    row = minr;
    col = minc;
    // printf("%d %d\n", row, col);
  }
};

int day5(line_view);

} // namespace aoc2020