算法-生命游戏(289矩阵)

leetcode题目链接

这道题要求能考虑在原地算法解决本题,请注意,面板上所有格子需要同时被更新:你不能先更新某些格子,然后使用它们的更新后的值再更新其他格子。

这样的话我们就必须先定义一下标准,标记哪些位置该改变,而哪些位置不需要变化。

我们可以这样设计一个模拟:

0:死细胞转为死细胞

1:活细胞转为活细胞

2:活细胞转为死细胞

3:死细胞转为活细胞

之后呢,我们就可以依据该位置的值来进行死活细胞转换,下面是代码

cpp 复制代码
class Solution {
public:
    void gameOfLife(vector<vector<int>>& board) {
         int m = board.size();
        int n = board[0].size();

        // 方向数组,用于遍历八个方向
        vector<int> dx = {-1, -1, -1, 0, 0, 1, 1, 1};
        vector<int> dy = {-1, 0, 1, -1, 1, -1, 0, 1};

        for (int i = 0; i < m; ++i) {
            for (int j = 0; j < n; ++j) {
                int liveNeighbors = 0;

                // 计算活邻居的数量
                for (int k = 0; k < 8; ++k) {
                    int ni = i + dx[k];
                    int nj = j + dy[k];

                    if (ni >= 0 && ni < m && nj >= 0 && nj < n && (board[ni][nj] == 1 || board[ni][nj] == 2)) {
                        ++liveNeighbors;
                    }
                }

                // 根据规则更新状态
                if (board[i][j] == 1) {
                    if (liveNeighbors < 2 || liveNeighbors > 3) {
                        board[i][j] = 2;  // 活细胞转为死细胞
                    }
                } else {
                    if (liveNeighbors == 3) {
                        board[i][j] = 3;  // 死细胞转为活细胞
                    }
                }
            }
        }

        // 将状态转换回0和1
        for (int i = 0; i < m; ++i) {
            for (int j = 0; j < n; ++j) {
                if (board[i][j] == 2) {
                    board[i][j] = 0;
                } else if (board[i][j] == 3) {
                    board[i][j] = 1;
                }
            }
        }
    }
};

解释

  1. 状态编码 :用 2 表示活细胞转死,用 3 表示死细胞转活。
  2. 邻居计算 :使用方向数组计算每个细胞的活邻居数时,检查 12 状态。
  3. 状态更新 :根据邻居数更新细胞的状态,但不立即改变 01,而是用 23 表示过渡状态。
  4. 最终转换 :遍历整个面板,将 2 转为 03 转为 1,得到下一个状态。
相关推荐
CoovallyAIHub6 分钟前
为你的 2026 年计算机视觉应用选择合适的边缘 AI 硬件
深度学习·算法·计算机视觉
汉克老师6 分钟前
GESP2025年12月认证C++六级真题与解析(单选题8-15)
c++·算法·二叉树·动态规划·哈夫曼编码·gesp6级·gesp六级
刘立军10 分钟前
程序员应该熟悉的概念(8)嵌入和语义检索
人工智能·算法
im_AMBER26 分钟前
Leetcode 95 分割链表
数据结构·c++·笔记·学习·算法·leetcode·链表
Boilermaker199234 分钟前
[算法基础] FooldFill(DFS、BFS)
算法·深度优先·宽度优先
leiming641 分钟前
c++ find 算法
算法
CoovallyAIHub43 分钟前
YOLOv12之后,AI在火场如何进化?2025最后一篇YOLO论文揭示:要在浓烟中看见关键,仅靠注意力还不够
深度学习·算法·计算机视觉
梭七y43 分钟前
【力扣hot100题】(121)反转链表
算法·leetcode·链表
qq_433554541 小时前
C++字符串hash
c++·算法·哈希算法
无限进步_1 小时前
【C语言】堆(Heap)的数据结构与实现:从构建到应用
c语言·数据结构·c++·后端·其他·算法·visual studio