蓝桥杯 n进制小数
来源:互联网 发布:印度火车知乎 编辑:程序博客网 时间:2024/04/28 02:00
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");
}
void main ( )
{
double dTestNo= 0.795;
int iBase;
for(iBase=2;iBase<=9;iBase++)
fun(dTestNo,iBase);
printf("\n");
}
代码:
#include<iostream>#include<cstring>#include<cmath>using namespace std;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]=floor(dTestNo);//cmath中的向下取整函数floor(),向上取整为ceil()if(iT[iNo]<iBase){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");}
- 蓝桥杯 n进制小数
- 蓝桥杯 n进制小数
- 蓝桥杯-N进制小数
- n进制小数
- N进制小数
- N进制小数
- N进制小数
- 蓝桥杯 代码填空 N进制小数
- 蓝桥杯 代码填空 n进制小数
- 112.n进制小数
- 2011蓝桥杯【初赛试题】n进制小数
- 【第二届蓝桥杯】n进制小数
- POJ 2635 N进制大数与小数取模
- math-n进制表示的小数
- nth_element-第n小数
- //截取n位小数
- 小数进制转换
- 【js】小数保留n位小数
- sikuli自动化测试中界面一致性比较中不容易注意的一点说明
- ubuntu 13.04 安装 chrome (软件源)
- linux介绍
- input type 有哪些,分别是什么意思
- R语言数据挖掘相关包的介绍
- 蓝桥杯 n进制小数
- Android向Server端发送JSON格式数据
- AdviceWith camel
- mtk UART 波特率设置
- Handler 应用解析
- Downloading the Source Tree
- 多线程—04—守护线程、interrupt、join、yield、线程优先级
- Initializing a Build Environment
- Modelsim+Debussy联合使用