蓝桥杯-N进制小数

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表示进制数。请填写缺失的部分。

*Copyright (c) 2015, 烟台大学计算机与控制工程学院
* All rights reserved.
* 文件名称:main.c
* 作者:徐吉平
* 完成日期:2017年1月19日
* 版本号:
* 问题描述:n进制小数

* 输入描述:
* 程序输出:进制转换结果


[cpp]  view plain  copy
  1. #include <stdio.h>  
  2. void fun(double dTestNo, int iBase)//待转的十进制小数。iBase表示进制数  
  3. {  
  4.     int iT[8];  
  5.     int iNo;  
  6.               //dTestNo 是double型的  
  7.     printf("十进制正小数 %f 转换成 %d 进制数为: ",dTestNo, iBase);  
  8.   
  9.     for(iNo=0;iNo<8;iNo++)  
  10.     {  
  11.         dTestNo *= iBase;  
  12.         iT[iNo] = (int)dTestNo;  
  13.         if(dTestNo>=1.0) dTestNo -= iT[iNo];  
  14.     }  
  15.   
  16.     printf("0.");  
  17.     for(iNo=0; iNo<8; iNo++) printf("%d", iT[iNo]);  
  18.     printf("\n");  
  19. }  
  20.   
  21. int main ( )  
  22. {  
  23.     double dTestNo= 0.795;//待转的十进制小数  
  24.     int iBase;            //进制数  
  25.   
  26.     for(iBase=2;iBase<=9;iBase++)  
  27.         fun(dTestNo,iBase);  
  28.     printf("\n");  
  29.   
  30.     return 0;  
  31. }  

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值