150个热门面试问题实战集:生命游戏——代码实例解析
最编程
2024-02-21 21:43:51
...
3.1 思路一——暴力求解
3.2 思路二——原地算法
3.3 思路三——优化(位运算)
在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。
3.4 思路四——位运算,但是copy存储在board数组中
上一篇: 如何轻松搞定Pycharm安装:一份实用的详尽安装指南
下一篇: 微服务篇之注册中心