Algorithms_in_C++ 1.0.0
Set of algorithms implemented in C++.
count_of_set_bits.cpp File Reference

Implementation to count number of set bits of a number in an integer. More...

#include <cassert>
#include <iostream>
Include dependency graph for count_of_set_bits.cpp:

Namespaces

namespace  bit_manipulation
 for IO operations
 
namespace  count_of_set_bits
 Functions for the count sets bits implementation.
 

Functions

std::uint64_t bit_manipulation::count_of_set_bits::countSetBits (std ::int64_t n)
 The main function implements set bit count. More...
 
static void test ()
 
int main ()
 Main function. More...
 

Detailed Description

Implementation to count number of set bits of a number in an integer.

We are given an integer number. We need to calculate the number of set bits in it.

A binary number consists of two digits. They are 0 & 1. Digit 1 is known as set bit in computer terms. Worst Case Time Complexity: O(log n) Space complexity: O(1)

Author
Swastika Gupta
Prashant Thakur

Function Documentation

◆ countSetBits()

std::uint64_t bit_manipulation::count_of_set_bits::countSetBits ( std ::int64_t  n)

The main function implements set bit count.

Parameters
nis the number whose set bit will be counted
Returns
total number of set-bits in the binary representation of number n
36 { // int64_t is preferred over int so that
37 // no Overflow can be there.
38
39 int count = 0; // "count" variable is used to count number of set-bits('1') in
40 // binary representation of number 'n'
41 while (n != 0)
42 {
43 ++count;
44 n = (n & (n - 1));
45 }
46 return count;
47 // Why this algorithm is better than the standard one?
48 // Because this algorithm runs the same number of times as the number of
49 // set-bits in it. Means if my number is having "3" set bits, then this while loop
50 // will run only "3" times!!
51}
Here is the call graph for this function:

◆ main()

int main ( void  )

Main function.

Returns
0 on exit
78 {
79 test(); // run self-test implementations
80 return 0;
81}

◆ test()

static void test ( )
static
55 {
56 // n = 4 return 1
57 assert(bit_manipulation::count_of_set_bits::countSetBits(4) == 1);
58 // n = 6 return 2
59 assert(bit_manipulation::count_of_set_bits::countSetBits(6) == 2);
60 // n = 13 return 3
61 assert(bit_manipulation::count_of_set_bits::countSetBits(13) == 3);
62 // n = 9 return 2
63 assert(bit_manipulation::count_of_set_bits::countSetBits(9) == 2);
64 // n = 15 return 4
65 assert(bit_manipulation::count_of_set_bits::countSetBits(15) == 4);
66 // n = 25 return 3
67 assert(bit_manipulation::count_of_set_bits::countSetBits(25) == 3);
68 // n = 97 return 3
69 assert(bit_manipulation::count_of_set_bits::countSetBits(97) == 3);
70 // n = 31 return 5
71 assert(bit_manipulation::count_of_set_bits::countSetBits(31) == 5);
72 std::cout << "All test cases successfully passed!" << std::endl;
73}
T endl(T... args)