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/

相关推荐
方安乐33 分钟前
python之向量、向量和、向量点积
开发语言·python·numpy
Old Uncle Tom2 小时前
OpenClaw 记忆系统 -- 记忆预加载
java·数据结构·算法·agent
会编程的土豆2 小时前
洛谷题单入门1 顺序结构
数据结构·算法·golang
小小小米粒2 小时前
Collection单列集合、Map(Key - Value)双列集合,多继承实现。
java·开发语言·windows
生信碱移2 小时前
PACells:这个方法可以鉴定疾病/预后相关的重要细胞亚群,作者提供的代码流程可以学习起来了,甚至兼容转录组与 ATAC 两种数据类型!
人工智能·学习·算法·机器学习·数据挖掘·数据分析·r语言
前端一小卒3 小时前
我用 Claude Code 的 Superpowers 技能链写了个服务,部署前差点把服务器搞炸
前端·javascript·后端
智者知已应修善业3 小时前
【51单片机中的打飞机设计】2023-8-25
c++·经验分享·笔记·算法·51单片机
czhc11400756633 小时前
C# 428 线程、异步
开发语言·c#
:1213 小时前
java基础
java·开发语言
圣保罗的大教堂4 小时前
leetcode 1855. 下标对中的最大距离 中等
leetcode