Rust 力扣 - 289. 生命游戏

文章目录

题目描述

题解思路

我们记录上一行和当前行转换之后的状态,当前行转换之后的状态计算完毕后调整上一行状态,直至最后一行状态计算完毕后调整最后一行状态

题解代码

rust 复制代码
pub fn game_of_life(board: &mut Vec<Vec<i32>>) {
    let (m, n) = (board.len(), board[0].len());
    let mut rows = vec![vec![0; n].clone(); 2];

    let live = |board: &Vec<Vec<i32>>, i: usize,  j: usize| -> i32 {
        let mut lives = 0;

        // 上
        if i > 0 {
            lives += board[i - 1][j];
        }

        // 下
        if i + 1 < m {
            lives += board[i + 1][j];
        }
    
        // 左
        if j > 0 {
            lives += board[i][j - 1];

            // 左上
            if i > 0 {
                lives += board[i - 1][j - 1];
            }

            // 左下
            if i + 1 < m {
                lives += board[i + 1][j - 1];
            }
        }
    
        // 右
        if j + 1 < n {
            lives += board[i][j + 1];
            
            // 右上
            if i > 0 {
                lives += board[i - 1][j + 1];
            }

            // 右下
            if i + 1 < m {
                lives += board[i + 1][j + 1];
            }
        }

        if board[i][j] == 1 {
            if lives < 2 || lives > 3 {
                0
            } else {
                1
            }
        } else {
            if lives == 3 {
                1
            } else {
                0
            }
        }
    };

    for i in 0..n {
        rows[0][i] = live(board, 0, i);
    }

    for i in 1..m {
        for j in 0..n {
            rows[i % 2][j] = live(board, i, j);
        }

        for j in 0..n {
            board[i - 1][j] = rows[(i - 1) % 2][j];
        }
    }

    for i in 0..n {
        board[m - 1][i] = rows[(m - 1) % 2][i];
    }
}

题目链接

https://leetcode.cn/problems/game-of-life/description/

相关推荐
圣保罗的大教堂1 分钟前
leetcode 1391. 检查网格中是否存在有效路径 中等
leetcode
计算机安禾6 分钟前
【c++面向对象编程】第29篇:定位new(placement new):在指定内存上构造对象
开发语言·c++·算法
淞綰9 分钟前
c语言的练习-字符串的练习-寻找最长连续字符以及出现次数
c语言·数据结构·学习·算法·c语言的练习
计算机安禾11 分钟前
【c++面向对象编程】第27篇:空类的大小为什么是1?——C++对象标识的秘密
开发语言·c++·算法
河阿里11 分钟前
Python容器:特性、区别和使用场景
开发语言·python
我不是8神11 分钟前
面试题:Gorutine泄露的条件有哪些?
java·开发语言
奇树谦12 分钟前
QListView和QListWidget区别详细说明
开发语言
郭龙_Jack13 分钟前
Java并发包(JUC)深度解析:从LockSupport到云原生演进
开发语言·云原生·java并发编程
大熊程序猿14 分钟前
ASP.NET Core 认证授权:JWT与OAuth2实战
后端·asp.net
Highcharts.js15 分钟前
AI向量知识谱系图表创建示例代码|Highcharts网络图表(networkgraph)搭建案例
开发语言·前端·javascript·网络·信息可视化·编辑器·highcharts