Leetcode—289. 生命游戏【中等】

2024每日刷题(126)

Leetcode---289. 生命游戏

算法思想

实现代码

cpp 复制代码
class Solution {
public:
    void gameOfLife(vector<vector<int>>& board) {
        int rows = board.size();
        int cols = board[0].size();
        int neighbors[3] = {0, 1, -1};

        vector<vector<int>> copyBoard(rows, vector<int>(cols, 0));
        for(int i = 0; i < rows; i++) {
            for(int j = 0; j < cols; j++) {
                copyBoard[i][j] = board[i][j];
            }
        }

        int r, c;
        for(int i = 0; i < rows; i++) {
            for(int j = 0; j < cols; j++) {
                int liveNum = 0;
                for(int row = 0; row < 3; row++) {
                    for(int col = 0; col < 3; col++) {
                        if(!(neighbors[row] == 0 && neighbors[col] == 0)) {
                            r = i + neighbors[row];
                            c = j + neighbors[col];
                            if((r >= 0 && r < rows) && (c >= 0 && c < cols) &&(copyBoard[r][c] == 1)) {
                                liveNum++;
                            }
                        }
                    }
                }

                // 条件1、3
                if((board[i][j] == 1) && (liveNum < 2 || liveNum > 3)) {
                    board[i][j] = 0;
                }
                // 条件4
                if(board[i][j] == 0 && liveNum == 3) {
                    board[i][j] = 1;
                }
            }
        }
    }
};

运行结果


之后我会持续更新,如果喜欢我的文章,请记得一键三连哦,点赞关注收藏,你的每一个赞每一份关注每一次收藏都将是我前进路上的无限动力 !!!↖(▔▽▔)↗感谢支持!

相关推荐
YGGP10 分钟前
【Golang】LeetCode 56. 合并区间
算法·leetcode·职场和发展
_F_y10 分钟前
回文串系列动态规划附马拉车算法原理及实现
算法·动态规划
你怎么知道我是队长18 分钟前
C语言---排序算法12---计数排序法
c语言·算法·排序算法
fu的博客23 分钟前
【数据结构2】带头结点·单向链表实现
数据结构·算法·链表
近津薪荼25 分钟前
优选算法——前缀和(6):和可被 K 整除的子数组
c++·算法
白太岁25 分钟前
通信:(2) TCP/UDP、流量/拥塞控制、ARP 与 Socket 应用
网络·c++·tcp/ip·udp
haierccc25 分钟前
2026年贺新春:Reflexive Arcade 游戏合集下载
游戏
lifallen26 分钟前
线性基 (Linear Basis)
数据结构·算法
twilight_46929 分钟前
人工智能数学基础——第二章 高等数学基础
人工智能·算法·机器学习
_OP_CHEN31 分钟前
【算法提高篇】(二)线段树之区间修改:懒标记的核心奥义与实战实现
算法·蓝桥杯·线段树·c/c++·区间查询·acm/icpc·懒标记