vgghhhgllljh 2021-11-21 13:04 采纳率: 50%
浏览 242
已结题

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

** 计算并返回 |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;
}

展开全部

  • 写回答

2条回答 默认 最新

  • 关注
    #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;
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)
编辑
预览

报告相同问题?

问题事件

  • 系统已结题 5月20日
  • 已采纳回答 5月13日
  • 创建了问题 11月21日

悬赏问题

  • ¥15 点云密度大则包围盒小
  • ¥15 nginx使用nfs进行服务器的数据共享
  • ¥15 C#i编程中so-ir-192编码的字符集转码UTF8问题
  • ¥15 51嵌入式入门按键小项目
  • ¥30 海外项目,如何降低Google Map接口费用?
  • ¥15 fluentmeshing
  • ¥15 手机/平板的浏览器里如何实现类似荧光笔的效果
  • ¥15 盘古气象大模型调用(python)
  • ¥15 传人记程序做的plc 485从机程序该如何写
  • ¥15 已知手指抓握过程中掌指关节、手指各关节和指尖每一帧的坐标,用贝塞尔曲线可以拟合手指抓握的运动轨迹吗?