Problem#
給你一個字串 s
你可以把它從任意 index 切成兩半,問你左邊字串 0
的數量與右邊字串 1
的數量相加最大多少?
測資限制#
- $2 \le n \le 500$
給你一個 32-bit 的無號整數,要你回傳有幾個 1 (又稱作 Hamming weight
)。
Naive: 每個 bit 都檢查是不是 1 然後記數。
Improve: 每次找最右邊的 1-bit,可以把數字 $n$ 與 $n-1$ 做 AND 運算,因為減一的話最右邊的 1 就會被消滅,經過 and 運算就會消失,直到變成 0。
或是可以用編譯器內建的 __builtin_popcount()