首頁 > 後端開發 > C++ > 如何有效地確定一個數字是否是2的力量?

如何有效地確定一個數字是否是2的力量?

Linda Hamilton
發布: 2025-01-29 19:41:09
原創
412 人瀏覽過

How to Efficiently Determine if a Number is a Power of 2?

如何高效地判斷一個數是否為2的冪

問題:

如何在不使用浮點運算或位移運算的情況下,高效地判斷給定的數字是否為2的冪?

答案:

一個簡單高效的算法如下:

<code class="language-c#">bool IsPowerOfTwo(ulong number)
{
    return (number != 0) && ((number & (number - 1)) == 0);
}</code>
登入後複製

解釋:

位與運算符 (&) 比較操作數的每一位,如果兩個位都為 1,則返回 1,否則返回 0。通過從數字中減去 1,我們創建一個二進制數,其中最低有效位(在原數字中設置為 1 的位)設置為 1。如果原數字是 2 的冪,則減去 1 將清除最高設置位右側的所有位,使與運算的結果為 0。相反,如果原數字不是 2 的冪,則在減去 1 後,數字的二進製表示中將至少有兩個位設置為 1,導致與運算的結果為非零值。

示例:

考慮數字 8(二進制 1000)。減去 1 得到 7(二進制 0111),它只有一位設置為 1。8 和 7 的位與運算結果為 0,表明 8 是 2 的冪。

注意:

上述算法對 0 返回 true,而 0 不是 2 的冪。如果您想排除 0,可以修改算法如下:

<code class="language-c#">bool IsPowerOfTwo(ulong number)
{
    return (number > 0) && ((number & (number - 1)) == 0);
}</code>
登入後複製

以上是如何有效地確定一個數字是否是2的力量?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板