4月打卡活动第2天 LeetCode第289题:生命游戏(中等)

    题目:给定一个包含 m × n 个格子的面板,每一个格子都可以看成是一个细胞。每个细胞都具有一个初始状态:1 即为活细胞(live),或 0 即为死细胞(dead)。每个细胞与其八个相邻位置(水平,垂直,对角线)的细胞都遵循以下四条生存定律: 1、如果活细胞周围八个位置的活细胞数少于两个,则该位置活细胞死亡; 2、如果活细胞周围八个位置有两个或三个活细胞,则该位置活细胞仍然存活; 3、如果活细胞周围八个位置有超过三个活细胞,则该位置活细胞死亡; 4、如果死细胞周围正好有三个活细胞,则该位置死细胞复活; 根据当前状态,写一个函数来计算面板上所有细胞的下一个(一次更新后的)状态。下一个状态是通过将上述规则同时应用于当前状态下的每个细胞所形成的,其中细胞的出生和死亡是同时发生的。 解题思路:创建一个新的数组记录该细胞周围活细胞的数量。
class Solution {
          
   
    public void gameOfLife(int[][] board) {
          
   
        int len = board.length;
        int leng = board[0].length;
        int[][] bb = new int[len][leng];
        for(int i=0;i<len;i++){
          
   
            for(int j=0;j<leng;j++){
          
   
                int num = 0;
                if(i>0 && board[i-1][j]==1) num++;
                if(i>0 && j>0 && board[i-1][j-1]==1) num++;
                if(j>0 && board[i][j-1]==1) num++;
                if(i>0 && j<leng-1 && board[i-1][j+1]==1) num++;
                if(i<len-1 && board[i+1][j]==1) num++;
                if(i<len-1 && j<leng-1 && board[i+1][j+1]==1) num++;
                if(i<len-1 && j>0 && board[i+1][j-1]==1) num++;
                if(j<leng-1 && board[i][j+1]==1) num++;
                bb[i][j] = num;
            }
        }
        for(int i=0;i<len;i++){
          
   
            for(int j=0;j<leng;j++){
          
   
                if(board[i][j]==1){
          
   
                    if(bb[i][j]<2 || bb[i][j]>3){
          
   
                        board[i][j]=0;
                    }
                }else{
          
   
                    if(bb[i][j]==3){
          
   
                        board[i][j]=1;
                    }
                }
            }
        }
    }
}
    题解做法:定义一个复合状态,这个方法之前用过,不过还是需要遍历两遍,就没采用这种方法。
经验分享 程序员 微信小程序 职场和发展