Leetcode 289 Solution
This article provides solution to leetcode question 289 (game-of-life).
Access this page by simply typing in "lcs 289" in your browser address bar if you have bunnylol configured.
Leetcode Question Link
https://leetcode.com/problems/game-of-life
Solution
class Solution {
public:
void gameOfLife(vector<vector<int>>& board) {
int m = board.size();
if (m == 0)
return;
int n = board[0].size();
const int dx[8] = {-1, -1, -1, 0, 1, 1, 1, 0};
const int dy[8] = {-1, 0, 1, 1, 1, 0, -1, -1};
for (int i = 0; i < m; i++)
{
for (int j = 0; j < n; j++)
{
int cnt = 0;
for (int k = 0; k < 8; k++)
{
if (i + dy[k] < 0 || i + dy[k] >= m)
continue;
if (j + dx[k] < 0 || j + dx[k] >= n)
continue;
if (board[i + dy[k]][j + dx[k]] & 1)
cnt++;
}
if (((board[i][j] & 1) == 1) && cnt >= 2 && cnt <= 3)
board[i][j] |= 2;
else if (((board[i][j] & 1) == 0) && cnt == 3)
board[i][j] |= 2;
}
}
for (int i = 0; i < m; i++)
{
for (int j = 0; j < n; j++)
{
board[i][j] = board[i][j] >> 1;
}
}
}
};