懒人读算法(二)-细胞问题

2024-06-16 18:32
文章标签 懒人 算法 细胞 问题

本文主要是介绍懒人读算法(二)-细胞问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

细胞问题:
每个细胞有两种状态:1为活细胞,0为死细胞,对于每个位置都满足如下的条件:

  1. 如果活细胞周围八个位置的活细胞数少于两个,则该位置活细胞死亡

  2. 如果活细胞周围八个位置有两个或三个活细胞,则该位置活细胞仍然存活

  3. 如果活细胞周围八个位置有超过三个活细胞,则该位置活细胞死亡

  4. 如果死细胞周围正好有三个活细胞,则该位置死细胞复活


public class Solution {public void gameOfLife(int[][] board) {if(board == null || board.length == 0) {return;}int m = board.length;int n = board[0].length;for(int i = 0; i < m; i++) {for(int j = 0; j < n; j++) {int lives = liveNeighbors(board, m, n, i, j);if(board[i][j] ==  1 && lives >= 2 && lives <= 3) {//有两个或三个则繁衍下一代board[i][j] = 3;}if(board[i][j] == 0 && lives == 3) {//如果死细胞周围正好有三个活细胞,则该位置死细胞复活board[i][j] = 2;}}}for(int i = 0; i < m; i++) {for(int j = 0; j < n; j++) {board[i][j] >>= 1;//经过一轮后,状态0和2就变成死细胞,状态1和3就是活细胞}}}private int liveNeighbors(int[][] board, int m, int n, int i, int j) {int lives = 0;for(int x = Math.max(i - 1, 0); x <= Math.min(i + 1, m - 1); x++) {for(int y = Math.max(j - 1, 0); y <= Math.min(j + 1, n - 1); y++) {lives += board[x][y] & 1;}}lives -= board[i][j] & 1;//减去自己return lives;}}

下面我对代码进行解答:

      int lives = 0;for(int x = Math.max(i - 1, 0); x <= Math.min(i + 1, m - 1); x++) {for(int y = Math.max(j - 1, 0); y <= Math.min(j + 1, n - 1); y++) {lives += board[x][y] & 1;}}

代码解析:

  1. 双重for循环就是先循环行,再循环当前行的列
  2. max(i-1,0)就是取最大值,如果i为0的话就取0,i为2的话的就取1
  3. 同理,min(i+1,m-1)就是当前1行和最大行做比较
  4. &为与计算,当前仅当两个都为1时才为1
   for(int i = 0; i < m; i++) {for(int j = 0; j < n; j++) {board[i][j] >>= 1;//经过一轮后,状态0和2就变成死细胞,状态1和3就是活细胞}}

代码解析:

  1. >>=是把当前值(先转二进制)向右移后赋予前面的值
  2. 例如7>>=1则是111(二进制的7)向右移变为11(二进制的3)则原先的7变为3

这篇关于懒人读算法(二)-细胞问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1067213

相关文章

linux生产者,消费者问题

pthread_cond_wait() :用于阻塞当前线程,等待别的线程使用pthread_cond_signal()或pthread_cond_broadcast来唤醒它。 pthread_cond_wait() 必须与pthread_mutex 配套使用。pthread_cond_wait()函数一进入wait状态就会自动release mutex。当其他线程通过pthread

问题:第一次世界大战的起止时间是 #其他#学习方法#微信

问题:第一次世界大战的起止时间是 A.1913 ~1918 年 B.1913 ~1918 年 C.1914 ~1918 年 D.1914 ~1919 年 参考答案如图所示

2024.6.24 IDEA中文乱码问题(服务器 控制台 TOMcat)实测已解决

1.问题产生原因: 1.文件编码不一致:如果文件的编码方式与IDEA设置的编码方式不一致,就会产生乱码。确保文件和IDEA使用相同的编码,通常是UTF-8。2.IDEA设置问题:检查IDEA的全局编码设置和项目编码设置是否正确。3.终端或控制台编码问题:如果你在终端或控制台看到乱码,可能是终端的编码设置问题。确保终端使用的是支持你的文件的编码方式。 2.解决方案: 1.File -> S

vcpkg安装opencv中的特殊问题记录(无法找到opencv_corexd.dll)

我是按照网上的vcpkg安装opencv方法进行的(比如这篇:从0开始在visual studio上安装opencv(超详细,针对小白)),但是中间出现了一些别人没有遇到的问题,虽然原因没有找到,但是本人给出一些暂时的解决办法: 问题1: 我在安装库命令行使用的是 .\vcpkg.exe install opencv 我的电脑是x64,vcpkg在这条命令后默认下载的也是opencv2:x6

问题-windows-VPN不正确关闭导致网页打不开

为什么会发生这类事情呢? 主要原因是关机之前vpn没有关掉导致的。 至于为什么没关掉vpn会导致网页打不开,我猜测是因为vpn建立的链接没被更改。 正确关掉vpn的时候,会把ip链接断掉,如果你不正确关掉,ip链接没有断掉,此时你vpn又是没启动的,没有域名解析,所以就打不开网站。 你可以在打不开网页的时候,把vpn打开,你会发现网络又可以登录了。 方法一 注意:方法一虽然方便,但是可能会有

代码随想录算法训练营:12/60

非科班学习算法day12 | LeetCode150:逆波兰表达式 ,Leetcode239: 滑动窗口最大值  目录 介绍 一、基础概念补充: 1.c++字符串转为数字 1. std::stoi, std::stol, std::stoll, std::stoul, std::stoull(最常用) 2. std::stringstream 3. std::atoi, std

人工智能机器学习算法总结神经网络算法(前向及反向传播)

1.定义,意义和优缺点 定义: 神经网络算法是一种模仿人类大脑神经元之间连接方式的机器学习算法。通过多层神经元的组合和激活函数的非线性转换,神经网络能够学习数据的特征和模式,实现对复杂数据的建模和预测。(我们可以借助人类的神经元模型来更好的帮助我们理解该算法的本质,不过这里需要说明的是,虽然名字是神经网络,并且结构等等也是借鉴了神经网络,但其原型以及算法本质上还和生物层面的神经网络运行原理存在

vue同页面多路由懒加载-及可能存在问题的解决方式

先上图,再解释 图一是多路由页面,图二是路由文件。从图一可以看出每个router-view对应的name都不一样。从图二可以看出层路由对应的组件加载方式要跟图一中的name相对应,并且图二的路由层在跟图一对应的页面中要加上components层,多一个s结尾,里面的的方法名就是图一路由的name值,里面还可以照样用懒加载的方式。 页面上其他的路由在路由文件中也跟图二是一样的写法。 附送可能存在

vue+elementui--$message提示框被dialog遮罩层挡住问题解决

最近碰到一个先执行this.$message提示内容,然后接着弹出dialog带遮罩层弹框。那么问题来了,message提示框会默认被dialog遮罩层挡住,现在就是要解决这个问题。 由于都是弹框,问题肯定是出在z-index比重问题。由于用$message方式是写在js中而不是写在html中所以不是很好直接去改样式。 不过好在message组件中提供了customClass 属性,我们可以利用

Visual Studio中,MSBUild版本问题

假如项目规定了MSBUild版本,那么在安装完Visual Studio后,假如带的MSBUild版本与项目要求的版本不符合要求,那么可以把需要的MSBUild添加到系统中,然后即可使用。步骤如下:            假如项目需要使用V12的MSBUild,而安装的Visual Studio带的MSBUild版本为V14。 ①到MSDN下载V12 MSBUild包,把V12包解压到目录(