2011蓝桥杯【初赛试题】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表示进制数。请填写缺失的部分。

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");

}

 

思路:首先要了解“十进制数小数部分如何转化成n进制数”

十进制数0.3转化成二进制数的方法如下:
0.3×2=0.6……整数部分为0,记0;
0.6×2=1.2……整数部分为1,记1;
0.2×2=0.4……整数部分为0,记0;
0.4×2=0.8……整数部分为0,记0;
0.8×2=1.6……整数部分为1,记1; ...

 

那么我们来看代码:

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] = (int) dTestNo ;//如上面的计算方法,只取整数部分

if(____dTestNo >1____) dTestNo -= iT[iNo];

//如果整数部分不是0而大于0,要去掉整数部分,因为下一次只能计算小数部分

//再者想,本题是小数转化为n进制,dTestNo就是个小数,凭这一点第二个空也应该转化成小数了

}

printf("0.");

for(iNo=0; iNo<8; iNo++)    printf("%d", iT[iNo]);

printf("\n");

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

光仔December

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

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

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

打赏作者

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

抵扣说明:

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

余额充值