TheAlgorithms/C++ 1.0.0
All the algorithms implemented in C++
Loading...
Searching...
No Matches
count_of_set_bits.cpp File Reference

Implementation to [count number of set bits of a number] (https://www.geeksforgeeks.org/count-set-bits-in-an-integer/) in an integer. More...

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

Go to the source code of this file.

Namespaces

namespace  bit_manipulation
 for assert
 
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.
 
static void test ()
 
int main ()
 Main function.
 

Detailed Description

Implementation to [count number of set bits of a number] (https://www.geeksforgeeks.org/count-set-bits-in-an-integer/) 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

Definition in file count_of_set_bits.cpp.

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

Definition at line 38 of file count_of_set_bits.cpp.

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

◆ main()

int main ( void )

Main function.

Returns
0 on exit

Definition at line 80 of file count_of_set_bits.cpp.

80 {
81 test(); // run self-test implementations
82 return 0;
83}

◆ test()

static void test ( )
static

Definition at line 57 of file count_of_set_bits.cpp.

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