在小慕的编程项目中,他需要分析一组二进制数据流,每个数据流由一串比特序列(二进制)组成,而不同序列的稳定性取决于它们最长的连续相同位(即连续的`0`或`1`)。 小慕试图优化这些数据流,以提高系统的运行效率,而项目导师则希望找到最稳定的数据模式。你的任务是,给定一个整数 `n`,计算其中最长的连续数字(0或1)的个数,帮助小慕完成项目分析!
提示:带虚线的词点一下有通俗解释。
输入描述
一个整数 `n`,其中 `0 <= n < 2^{32}`。
输出描述
一个整数,表示 `n` 的二进制表示中最长的连续 `0` 或 `1` 的个数。
示例
示例 1
输入
3
输出
2
说明:`3` 的二进制表示为 `11`,最长连续数字为 `11`,长度为 `2`。
示例 2
输入
17
输出
3
说明:`17` 的二进制表示为 `10001`,最长连续数字为 `000`,长度为 `3`。
示例 3
输入
0
输出
1
说明:`0` 的二进制表示为 `0`,最长连续数字的个数为 `1`。
时间限制 1000 ms · 内存限制 128 MB