1128: 【基础】二进制小数

1128: 【基础】二进制小数
时间限制: 1 Sec 内存限制: 16 MB
提交: 1605 解决: 1179
[提交] [状态] [讨论版] [命题人:外部导入]

题目描述
在十进制和二进制的转换中,不仅仅有整数部分的转换也有小数部分的转换。只不过,转换的方法不同,整数转换是除二取余再将所有余数倒置。而小数部分转换,是将10进制的小数部分不断乘2取整数部分完成的。但,很多情况下,转换后,小数部分是不能够被精确转换的,这就要精确到第多少位。请编写程序,将输入文件中的实数转换成二进制,并显示小数点后指定位上的数值。

输入
有一个十进制实数n和一个整数m

输出
只有一个一位数整数。表示实数n转换成二进制后,小数点后第m位上的整数。

样例输入
10.123 5

样例输出
1

来源/分类
2008海淀区模拟题


题解如下

#include<stdio.h>
#include<string.h>
#include<math.h>

int main()
{
    double n;
    int m;
    scanf("%lf%d",&n,&m);
    int zhi=(int)n;
    double decimals=n-zhi;
    int ar[m];
    for(int i=0;i<m;i++)
    {
        if(decimals*2>1)
        {
            ar[i]=1;
            (decimals*=2)-=1;
        }
        else
        {
            ar[i]=0;
            decimals*=2;
        }

    }
    printf("%d",ar[m-1]);

    return 0;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 原码就是一个字的二进制表示,反码就是将原码中的每一取反,十进制转换为二进制可以用除2取余的方法,二进制转换为十进制可以用二进制的权重相加的方法。例如:十进制10转换为二进制1010,其原码为1010,反码为1101,二进制11.11转换为十进制为3.75,其原码为11.11,反码为00.00。 ### 回答2: 二进制是计算机中最常用的制系统,它由0和1两个字组成。在进行二进制的转换时,我们需要了解原码和反码的概念。 原码是二进制的最基本表示形式,它是将十进制直接转换为二进制的形式。例如,十进制6在二进制中的原码是110。 反码是原码的一种特殊形式,它的计算方法是对原码的每个进行取反操作。也就是说,0变为1,1变为0。例如,原码110的反码是001。 对于整二进制,如果最高为1,表示该为负。为了能够表示负,我们需要引入补码的概念。 补码是反码加1得到的结果。例如,原码110的反码是001,补码则是010。 对于小数二进制,我们通常使用定点表示法。将小数点固定在某个置,左边的部分表示整,右边的部分表示小数。 在十进制二进制之间的转换中,我们可以使用乘二取整法和除二取余法。 对于整的转换,乘二取整法是将十进制每次乘以2,然后将结果的整部分作为二进制对应。例如,十进制13转换为二进制是1101。 对于小数的转换,除二取余法是将十进制每次除以2,然后将结果的小数部分作为二进制对应。例如,十进制0.75转换为二进制是0.11。 综上所述,二进制的原码、反码和补码表示了整在计算机中的存储方式,而定点表示法可以用来表示小数。通过乘二取整法和除二取余法,我们可以进行十进制二进制之间的转换。 ### 回答3: 二进制是一种使用两个字0和1来表示值的计系统。在二进制中,每个上的字称为比特或二进制二进制可以分为整小数两种类型。 对于整二进制,原码表示法是最简单的表示方法。该方法直接将十进制转化二进制,并在最高添加一个符号,0表示正,1表示负。例如,十进制7在原码表示法中对应二进制为0111,-7对应二进制为1111。 反码是在原码基础上的变化,用于表示负。反码的求解方法是将原码中的符号保持不变,其他取反。例如,十进制7对应的反码为0111,-7对应的反码为1000。 在十进制二进制之间进行转换时,只需将每个权上的字进行乘法运算,并将结果相加。例如,十进制13的二进制表示为1101,计算方法为1 * 2^3 + 1 * 2^2 + 0 * 2^1 + 1 * 2^0 = 8 + 4 + 0 + 1 = 13。同样地,二进制1101的十进制表示为1 * 2^3 + 1 * 2^2 + 0 * 2^1 + 1 * 2^0 = 8 + 4 + 0 + 1 = 13。 对于小数二进制,原码和反码的求解方法与整相同。例如,十进制0.5的二进制表示为0.1,计算方法是1 * 2^(-1) = 0.5。同样地,二进制0.1的十进制表示为1 * 2^(-1) = 0.5。 综上所述,二进制的原码、反码以及十进制二进制的转换方法都是根据权的乘法运算规则。无论是整还是小数,通过对每个进行权重计算并相加,可以准确地进行转换。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值