Write an efficient program to count number of 1s in binary representation of an integer.
Input : n = 6 Output : 2 Binary representation of 6 is 110 and has 2 set bits Input : n = 13 Output : 3 Binary representation of 11 is 1101 and has 3 set bits
In the previous post we had seen different method that solved this problem in O(log n) time. In this post we solve in O(1) using lookup table. Here we assume that the size of INT is 32-bits. It’s hard to count all 32 bits in one go using lookup table (” because it’s infeasible to create lookup table of size 232-1 “). So we break 32 bits into 8 bits of chunks( ow lookup table of size (28-1 ) index : 0-255 ).
In lookup tale, we store count of set_bit of every
number that are in a range (0-255)
LookupTable = 0 | binary 00000000 CountSetBits 0
LookupTable = 1 | binary 00000001 CountSetBits 1
LookupTable = 1 | binary 00000010 CountSetBits 1
LookupTanle = 2 | binary 00000011 CountSetBits 2
LookupTable = 1 | binary 00000100 CountSetBits 1
and so…on upto LookupTable.
Let’s take an Example How lookup table work.
Let's number be : 354 in Binary : 0000000000000000000000101100010 Split it into 8 bits chunks : In Binary : 00000000 | 00000000 | 00000001 | 01100010 In decimal : 0 0 1 98 Now Count Set_bits using LookupTable LookupTable = 0 LookupTable = 1 LookupTable = 3 so Total bits count : 4
Time Complexity : O(1)
- Check for Integer Overflow
- Write an Efficient C Program to Reverse Bits of a Number
- Count set bits in an integer
- Count number of bits to be flipped to convert A to B
- Rotate bits of a number
- Compute the integer absolute value (abs) without branching
- Multiply a given Integer with 3.5
- Next higher number with same number of set bits
- Program to count number of set bits in an (big) array
- Count total set bits in all numbers from 1 to n
- Swap bits in a given number
- Swap all odd and even bits
- Toggle all the bits of a number except k-th bit.
- Count inversions in an array | Set 3 (Using BIT)
- Count number of subsets having a particular XOR value
If you like GeeksforGeeks and would like to contribute, you can also write an article using contribute.geeksforgeeks.org or mail your article to firstname.lastname@example.org. See your article appearing on the GeeksforGeeks main page and help other Geeks.
Please Improve this article if you find anything incorrect by clicking on the "Improve Article" button below.