Given a floating point number, write a function to count set bits in its binary representation.
We can use the idea discussed here. The idea is to take address of the given floating point number in a pointer variable, typecast the pointer to char * type and process individual bytes one by one. We can easily count set bits in a char using the techniques discussed here.
Following is C implementation of the above idea.
Binary representation of 0.156250 has 6 set bits
This article is contrbuted by Vineet Gupta. Please write comments if you find anything incorrect, or you want to share more information about the topic discussed above
- Convert a floating point number to string in C
- Rounding Floating Point Number To two Decimal Places in C and C++
- Can we use % operator on floating point numbers?
- Floating Point Operations & Associativity in C, C++ and Java
- C Program to Multiply two Floating Point Numbers
- Write a one line C function to round floating point numbers
- C++ Floating Point Manipulation (fmod(), remainder(), remquo() ... in cmath)
- Precision of floating point numbers in C++ (floor(), ceil(), trunc(), round() and setprecision())
- Maximize the number by rearranging bits
- Find a number containing N - 1 set bits at even positions from the right
- sizeof() for Floating Constant in C
- Rotation of a point about another point in C++
- Count the number of 1's and 0's in a binary array using STL in C++ ?
- Count number of unique Triangles using STL | Set 1 (Using set)
- C Program to count the Number of Characters in a File