手机
当前位置:查字典教程网 >编程开发 >C语言 >将正小数转化为2-9进制小数的实现方法
将正小数转化为2-9进制小数的实现方法
摘要:将任意十进制正小数分别转换成2,3,4,5,6,7,8,9进制正小数,小数点后保留8位,并输出。例如:若十进制小数为0.795,则输出:十进...

将任意十进制正小数分别转换成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表示进制数。

复制代码 代码如下:

#include <stdio.h>

void fun(double dTestNo, int iBase)

{

int iT[8]; //转化后的小数保留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]; //减去整数部分

}

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

}

【将正小数转化为2-9进制小数的实现方法】相关文章:

atoi和itoa函数的实现方法

判断机器大小端的两种实现方法

随机加密程序的实现方法

c语言连接mysql数据库的实现方法

使用map实现单词转换的实例分析

自己实现strcpy函数的实现方法

C++中求组合数的各种方法总结详解

C 二分查找 递归与非递归的实现代码

C++十六进制宏的用法详解

基于WTL中使用双缓冲避免闪烁的解决方法

精品推荐
分类导航