Problem

Given a positive integer n, write a function that returns the number of set bits in its binary representation (also known as the Hamming weight).

Example 1: Input: n = 11 Output: 3 Explanation: The input binary string 1011 has a total of three set bits.

Example 2: Input: n = 128 Output: 1 Explanation: The input binary string 10000000 has a total of one set bit.

Example 3: Input: n = 2147483645 Output: 30 Explanation: The input binary string 1111111111111111111111111111101 has a total of thirty set bits.

Constraints:

  • 1 <= n <= 231 - 1

Follow up: If this function is called many times, how would you optimize it?

Solution

class Solution {
public:
    int hammingWeight(int n) {
        int count = 0;
        while (n > 0) {
            if (n & 1) count++;
            n >>= 1;
        }
        return count;
    }
};