-
Notifications
You must be signed in to change notification settings - Fork 9
/
Copy pathday_11b.cpp
99 lines (89 loc) · 2.48 KB
/
day_11b.cpp
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
86
87
88
89
90
91
92
93
94
95
96
97
98
99
#include <fstream>
#include <iostream>
#include <string>
#include <vector>
struct Point {
int row, col;
Point (const int row, const int col) : row(row), col(col) {}
friend std::ostream& operator << (std::ostream& os, const Point& p);
};
std::ostream& operator << (std::ostream& os, const Point& p) {
os << "(" << p.row << ", " << p.col << ")";
return os;
}
template<typename T>
void print(std::vector<std::vector<T>>& v) {
for (const auto& row : v) {
for(const auto ele : row) {
std::cout << ele;
}
std::cout << '\n';
}
}
int main(int argc, char * argv[]) {
std::string input = "../input/day_11_input";
if (argc > 1) {
input = argv[1];
}
std::string line;
std::fstream file(input);
std::vector<std::vector<int>> energy;
while(std::getline(file, line)) {
energy.emplace_back();
for (const auto c : line) {
energy.back().emplace_back(c - '0');
}
}
const auto get_neighbours = [](const int row, const int col){
return std::vector<Point> {
Point(row + 1, col),
Point(row - 1, col),
Point(row + 1, col + 1),
Point(row - 1, col + 1),
Point(row + 1, col - 1),
Point(row - 1, col - 1),
Point(row, col + 1),
Point(row, col - 1),
};
};
const auto in_bounds = [&energy] (const Point& p){
return p.row >=0 && p.row < energy.size() &&
p.col >=0 && p.col < energy[0].size();
};
long long step = 1;
const int n_octopuses = energy.size() * energy[0].size();
while(true) {
long long count = 0;
bool flash = true;
std::vector<std::vector<bool>> already_flashed(energy.size(), std::vector<bool>(energy[0].size(), false));
for (int row = 0; row < energy.size(); row++) {
for (int col = 0; col < energy[0].size(); col++) {
energy[row][col]++;
}
}
while(flash) {
flash = false;
for (int row = 0; row < energy.size(); row++) {
for (int col = 0; col < energy[0].size(); col++) {
if (energy[row][col] > 9 && !already_flashed[row][col]) {
already_flashed[row][col] = true;
energy[row][col] = 0;
flash = true;
count++;
for (const auto& nbr : get_neighbours(row, col)) {
if (in_bounds(nbr) && !already_flashed[nbr.row][nbr.col]) {
energy[nbr.row][nbr.col]++;
}
}
}
}
}
}
if (count == n_octopuses) {
std::cout << step << '\n';
break;
}
step++;
}
return 0;
}