任何人都可以解释以下代码的作用以及它是如何工作的
Could anyone please explain what the following code does and HOW it works?
我的老师说这是javascript,如果有帮助的话
function mystery(x) {
x--;
x|= x>> 1;
x|= x>> 2;
x|= x>> 4;
x|= x>> 8;
x|= x>> 16;
x++;
return x;
}
它找到大于或等于 x
的 2 的最低幂。或者,x--
之后的所有内容都将找到x-1
中所有位中剩余的最低位。
例如,如果您x - 1
为
00010100111010100001010011101010
那么mystery(x)
将是
00100000000000000000000000000000
它首先通过向右折叠来填充 1 后面的所有零;在第一次操作之后,每个操作后面都有一个。然后我们折叠两位组:每两个组现在将变成四个。然后我们折四个,然后是八个。然后我们拿出大锤子,十六个位。
00010100111010100001000000001100 // x - 1
00011110111111110001100000001110 // after folding one bit
00011111111111111101111000001111 // after 2
00011111111111111111111111101111 // after 4
00011111111111111111111111111111 // after 8, and every step thereafter
在这里,x++
将所有 1 切换为零,使一个进位到下一列:
00100000000000000000000000000000 // after x++
开始时奇怪的递减是让我们抓住<=
而不是严格的<
。例如,如果我们从
00000000000000000000000000000100 // x
00000000000000000000000000000011 // after x--
00000000000000000000000000000011 // after folding, unchanged - they're all ones anyway
00000000000000000000000000000100 // after x++
语句
x>> 1;
- 二进制表示中的 x 向右移动 1 位,丢弃移出的位
x|= x>> 1;
- 对
x
x >> 1
的结果执行按位 OR,并将结果存储在x
函数
mystery(x)
,得到数x
中 2 的下一个最高幂。初始递减语句(x--
)使函数返回相同的值,如果这个数字已经是2的幂。 当接近 INT_MAX_VALUE
时,mystery(x)
对有符号整数的行为会很有趣。
您可以通过绘制小值的函数值来得出此答案x
相关文章:
- Javascript:selenium Web驱动程序isDisplayed()不工作
- jQuery UI自动完成突然停止工作
- AngularJS UI路由器不能像ng路由器那样工作
- HTML5音频加载和播放获胜'我不能在iPad上工作
- JavaScript打印功能使日历停止工作
- Javascript.getHours()工作不正常
- 为什么这在IE中的工作方式与在Firefox中不同
- 视频HTML没有'无法在Internet Explorer 11上工作
- 扩展移相器按钮类不工作
- Firebase迁移-简单的Firebase.set没有'不再工作了——旧的还是新的
- 谷歌地图不是以HTML显示,而是在JS Fiddle上工作
- 正在尝试使用if和else添加类,但无法正常工作
- Jquery FadeIn FadeOut 只工作一次
- Foreach无法在Typescript中工作
- 另一个ajax调用中的Jquery ajax调用在for循环中没有按预期工作
- 为什么不是't窗口.恢复正常工作吗?(javascript/jquery)
- JS可以在Chrome中工作,但不能在Firefox中工作
- ajaxToolkit PopupControlExtender不工作.过时的
- HTML标记在脚本标记中工作
- 在JavaScript中的类中,push和concat的工作方式有何不同