为什么 ⌊lgN⌋=(N 的二进制表示的位数)-1
作者:互联网
《算法(第四版)》1.4.3.6 节下的“表 1.4.5 算法分析中的常见函数”中说:\(\lfloor \lg N\rfloor=(N\ 的二进制表示的位数)-1\),其中 N 为正整数。
为什么?
设 \(\lfloor \lg N \rfloor=k\)。
\[\begin{aligned} &\lfloor \lg N \rfloor=k\\ &\Rightarrow k\leq\lg N< k+1\\ &\Leftrightarrow 2^k\leq N < 2^{k+1}\\ &\Leftrightarrow \underbrace{(100..00)_2}_{k+1\ bit}\leq N < \underbrace{(111..11)_2}_{k+1\ bit}\\ \end{aligned} \]故 N 的二进制位数为 k+1,\(\lfloor \lg N\rfloor=(N\ 的二进制表示的位数)-1\)。
标签:lfloor,lg,lgN,二进制,rfloor,leq,位数 来源: https://www.cnblogs.com/Higurashi-kagome/p/15876829.html