Skip to content

Instantly share code, notes, and snippets.

@ajaysusarla
Created July 12, 2016 13:17
Show Gist options
  • Save ajaysusarla/1ceeff43d6043004cf1aa3e8dbf75891 to your computer and use it in GitHub Desktop.
Save ajaysusarla/1ceeff43d6043004cf1aa3e8dbf75891 to your computer and use it in GitHub Desktop.
Count bits
#include <stdint.h>
#include <limits.h>
#define numbits(x) (sizeof(x) * 8)
#define max_signed_value_of_type(t) \
(INTMAX_MAX >> (numbits(intmax_t) - numbits(t)))
void count_bits(unsigned int num)
{
size_t bits = numbits(num);
unsigned int max = max_signed_value_of_type(num) + 1;
int i;
unsigned int t = num;
int zeroes = 0, ones = 0;
for (i = 0; i < bits; i++) {
if (!!(num & max))
ones++;
else
zeroes++;
num = num << 1;
}
printf("%u has %d 0's and %d 1's in its binary representation.\n", t, zeroes, ones);
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment