【第二届蓝桥杯】n进制小数

题目:n进制小数


将任意十进制正小数分别转换成2,3,4,5,6,7,8,9进制正小数,小数点后保留8位,并输出。
例如:若十进制小数为0.795,则输出:
       十进制正小数0.795000 转换成 2 进制数为: 0.11001011
       十进制正小数0.795000 转换成 3 进制数为: 0.21011011
       十进制正小数0.795000 转换成 4 进制数为: 0.30232011
       十进制正小数0.795000 转换成 5 进制数为: 0.34414141
       十进制正小数0.795000 转换成 6 进制数为: 0.44341530
       十进制正小数0.795000 转换成 7 进制数为: 0.53645364
       十进制正小数0.795000 转换成 8 进制数为: 0.62702436
       十进制正小数0.795000 转换成 9 进制数为: 0.71348853
以下代码提供了这个功能。其中,dTestNo表示待转的十进制小数。iBase表示进制数。请填写缺失的部分。
把填空的答案(仅填空处的答案,不包括题面)存入考生文件夹下对应题号的“解答.txt”中即可。
void fun(double dTestNo, int iBase)
{
    int iT[8];
    int iNo;
 
    printf("十进制正小数 %f 转换成 %d 进制数为: ",dTestNo, iBase);
 
    for(iNo=0;iNo<8;iNo++)
    {
        dTestNo *= iBase;
        iT[iNo] = ________________;
        if(___________________) dTestNo -= iT[iNo];
    }
   
    printf("0.");
    for(iNo=0; iNo<8; iNo++) printf("%d", iT[iNo]);
    printf("\n");
}
 
void main ( )
{  
    double dTestNo= 0.795;
    int iBase;
 
    for(iBase=2;iBase<=9;iBase++)
        fun(dTestNo,iBase);
    printf("\n");

}


答案:(int)dTestNo
           dTestNo

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Homilier

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值