Eda Eren

December 21, 2024
  • Computer Science
  • TypeScript
  • JavaScript

LeetCode Meditations: Number of 1 Bits

Cover image

Let's start with the description for this one:

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).

For example:

Input: n = 11
Output: 3

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

Explanation: The input binary string 1011 has a total of three set bits.

Or:

Input: n = 128
Output: 1

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

Explanation: The input binary string 10000000 has a total of one set bit.

Or:

Input: n = 2147483645
Output: 30

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

Explanation: The input binary string 1111111111111111111111111111101 has a total of thirty set bits.

As we mentioned in the chapter introduction in the previous post, a set bit refers to a bit with the value of 1.

So, what we have to do is to count 1 bits.

One way to do it is to convert the number to a string, and just count the 1s. Or, we can convert that to an array and filter out the 0s, and get its length. But, there is another approach where we can use bit manipulation.

We can remove the set bits (bits that have the value 1) until the number becomes 0.

A good thing to know is that n - 1 is the rightmost set removed version of n.

For example, if n is 0010, n - 1 is 0001.

Or, if n is 0110, n - 1 is 0101.

We can create a loop that runs as long as there are 1 bits in n, counting each one as we go. Also each time, we can do an AND operation with n and 1 less of it (n & (n - 1)).

A simple TypeScript solution looks like this:

function hammingWeight(n: number): number {
let result = 0;
while (n > 0) {
n &= (n - 1);
result++;
}

return result;
}
function hammingWeight(n: number): number {
let result = 0;
while (n > 0) {
n &= (n - 1);
result++;
}

return result;
}

Time and space complexity

The time complexity is, I think, O(log n)O(log \ n) — In the worst case when all bits are set, we'll run through the loop log nlog \ n times (the number of bits in the binary representation of a number nn will be log nlog \ n).

The space complexity will be constant (O(1)O(1)) as there is no additional memory usage that will increase as the input increases.


The next problem we'll take a look at is Counting Bits. Until then, happy coding.