Fill in the return value for the following procedure, which tests whether its first argument is less than or equal to its second. Assume the function f2u returns an unsigned 32-bit number having the same bit representation as its floating-point argument. You can assume that neither argument is NaN. The two flavors of zero, +0 and -0, are considered equal.
intfloat_le(float x,float y) {unsigned ux =f2u(x);unsigned uy =f2u(y); /* Get the sign bits */unsigned sx = ux >>31;unsigned sy = uy >>31; /* Give an expression using only ux, uy, sx, and sy */return ____;}
Code:
#include<stdio.h>#include<assert.h>unsignedf2u(float x) {return*(unsigned*)&x;}intfloat_le(float x,float y) {unsigned ux =f2u(x);unsigned uy =f2u(y); /* Get the sign bits */unsigned sx = ux >>31;unsigned sy = uy >>31; /* Give an expression using only ux, uy, sx, and sy */return (ux <<1==0&& uy <<1==0) || /* both x and y equal to 0 */ (sx &&!sy) || /* x<0 and y>0 */ (sx && sy && ux >= uy) || (!sx &&!sy && ux <= uy);}intmain() {assert(float_le(-0.0,+0.0));assert(float_le(-3.0,1.0));assert(float_le(-4.0,-3.0));assert(float_le(1.0,2.0));return0;}