运用位运算,计算浮点数的绝对值

** 计算并返回 |x|**

定义函数

int MyAbs ( int x );

在以上函数中,参数 int x 中实际存储着一个浮点数,就是说:它的值不能够按照整数格式来解析,而应该将它的32个bit按照浮点数的格式来解析。

返回值虽然是整数类型,但也是按照浮点数格式保存的浮点数。

代码:

#include <stdio.h>

// 计算并返回 |x|
int MyAbs ( int x );

//代码将被填写在这里


int main()
{
    float x, y;
    int m, n;

    scanf("%f", &x);
    m = *(int*)&x; //复制bit值
    printf("x = %f\n", x);

    n = MyAbs( m );
    y = *(float*)&n; //复制bit值
    printf("|x| = %f\n", y);

    return 0;
}

#include <stdio.h>
// 计算并返回 |x|
int MyAbs(int x);
//代码将被填写在这里

int main()
{
    float x, y;
    int m, n;
    scanf("%f", &x);
    m = *(int *)&x; //复制bit值
    printf("x = %f\n", x);
    n = MyAbs(m);
    y = *(float *)&n; //复制bit值
    printf("|x| = %f\n", y);
    return 0;
}
int MyAbs(int x)
{
    return x&0x7fffffff;
}
您好,我是有问必答小助手,您的问题已经有小伙伴帮您解答,感谢您对有问必答的支持与关注!
PS:问答VIP年卡 【限时加赠:IT技术图书免费领】,了解详情>>> https://vip.csdn.net/askvip?utm_source=1146287632