Leetcode 191 - Number of 1 Bits

題目

Problem#

給你一個 32-bit 的無號整數,要你回傳有幾個 1 (又稱作 Hamming weight)。

想法#

Naive: 每個 bit 都檢查是不是 1 然後記數。
Improve: 每次找最右邊的 1-bit,可以把數字 $n$ 與 $n-1$ 做 AND 運算,因為減一的話最右邊的 1 就會被消滅,經過 and 運算就會消失,直到變成 0。
或是可以用編譯器內建的 __builtin_popcount()

AC Code#

  • 時間複雜度: $\mathcal{O}(1)$
  • 空間複雜度: $\mathcal{O}(1)$
  • 時間複雜度: $\mathcal{O}(1)$
  • 空間複雜度: $\mathcal{O}(1)$

心得#

Leetcode 1356 - Sort Integers by The Number of 1 Bits 一樣