浮点数二进制转换C语言程序,C语言验证浮点数的二进制表示

虽然以前也学过浮点数的表示原理,大致的原理还是清楚的,但是使用 C 语言的来进性验证还没有尝试过,下面是验证的过程

思路

知道浮点数,是按照 32 位在内存中保存,其中第一位表示符号,后 8 位表示指数,最后 23 位表示小数

C 语言当中存在指针,可以直接通过指针来获取,变量的地址。

所以就先定义一个变量来储存浮点数,在定义一个指针来获取,浮点数的储存地址,在把 16 进制或者 10 进制的地址转化为 2 进制即可

int main(void)

{

float a=209.125;

int *p=(int *)&a;

while(1){

printf("请输入一串数:");

scanf("%f",&a);

printf("%d\n", *p);//输出数值在内存中10进制表示

decimal2Binary(*p);//将十进制转化为二进制

decimal2Binary_2(*p);

}

getchar();//防止程序退出

return 0;

}

在十进制转化为二进制的过程中,我使用了两种办法,首先想到的就是通过循环求余的办法来转化

/**

* [decimal2Binary 十进制转换成二进制,使用循环求余法]

* @author mohuishou<1@lailin.xyz>

* @param x [要转换的十进制数]

<
  • 2
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值