欢迎您访问 最编程 本站为您分享编程语言代码,编程技术文章!
您现在的位置是: 首页

150个热门面试问题实战集:生命游戏——代码实例解析

最编程 2024-02-21 21:43:51
...

3.1 思路一——暴力求解

image-20240220091018158

3.2 思路二——原地算法

image-20240220101059273

image-20240220100955856

3.3 思路三——优化(位运算)

image-20240220105056115

在Java中,表达式 (copy[k] & (1 << (31 - l))) 并不直接结果为0或1,而是执行了一个按位与(&)操作,这个操作的结果取决于copy[k]在指定位上的值。这里的操作细节如下:

  • 1 << (31 - l):这部分是位移操作。它将数字1向左移动(31 - l)位。这意味着,如果l为0,那么1将被移动到最高位(假设是32位整数),如果l是其他值,1就会被移动到相应的位置上。这样做的目的是为了生成一个只在特定位置上有一个1的整数,其他位置都是0。

  • copy[k] & (1 << (31 - l)):这部分是按位与操作。它比较copy[k]和上面计算出的数值,在每个位上进行逻辑与操作。只有当copy[k]在相应的位上也是1时,这个操作的结果在那个位上才是1,否则结果为0。因此,这个表达式的结果是一个整数,它在大多数位上都是0,在特定的位上可能是0或者是2的某次幂(取决于l的值)。如果你想判断这个操作的结果是否为非零(即判断copy[k]在(31 - l)位上是否为1),你可以将整个表达式与0进行比较:

<span style="background-color:#f8f8f8"><span style="color:#008855">boolean</span> <span style="color:#000000">isBitSet</span> <span style="color:#981a1a">=</span><span style="color:#777777"> (</span><span style="color:#000000">copy</span><span style="color:#777777">[</span><span style="color:#000000">k</span><span style="color:#777777">] </span><span style="color:#981a1a">&</span> <span style="color:#777777">(</span><span style="color:#116644">1 << </span><span style="color:#777777">(</span><span style="color:#116644">31</span> <span style="color:#981a1a">-</span> <span style="color:#000000">l</span><span style="color:#777777">))) </span><span style="color:#981a1a">!=</span> <span style="color:#116644">0</span><span style="color:#777777">;</span></span>

如果你的目的是确保结果严格为0或1,你需要进一步处理这个表达式,例如通过判断表达式是否非零来将结果转换为0或1:

<span style="color:#777777"><span style="background-color:#f8f8f8"><span style="color:#008855">int</span> <span style="color:#000000">bitValue</span> <span style="color:#981a1a">=</span> (<span style="color:#000000">copy</span>[<span style="color:#000000">k</span>] <span style="color:#981a1a">&</span> (<span style="color:#116644">1</span> << (<span style="color:#116644">31</span> <span style="color:#981a1a">-</span> <span style="color:#000000">l</span>))) <span style="color:#981a1a">!=</span> <span style="color:#116644">0</span> <span style="color:#981a1a">?</span> <span style="color:#116644">1</span> : <span style="color:#116644">0</span>;</span></span>

这样,bitValue就会根据copy[k]在(31 - l)位上是否为1来分别存储1或0。

image-20240220105038951

3.4 思路四——位运算,但是copy存储在board数组中

image-20240220120852378

image-20240220120827412