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、付费专栏及课程。

余额充值