將正小數(shù)轉(zhuǎn)化為2-9進制小數(shù)的實現(xiàn)方法
將任意十進制正小數(shù)分別轉(zhuǎn)換成2,3,4,5,6,7,8,9進制正小數(shù),小數(shù)點后保留8位,并輸出。例如:若十進制小數(shù)為0.795,則輸出:
十進制正小數(shù) 0.795000 轉(zhuǎn)換成 2 進制數(shù)為: 0.11001011
十進制正小數(shù) 0.795000 轉(zhuǎn)換成 3 進制數(shù)為: 0.21011011
十進制正小數(shù) 0.795000 轉(zhuǎn)換成 4 進制數(shù)為: 0.30232011
十進制正小數(shù) 0.795000 轉(zhuǎn)換成 5 進制數(shù)為: 0.34414141
十進制正小數(shù) 0.795000 轉(zhuǎn)換成 6 進制數(shù)為: 0.44341530
十進制正小數(shù) 0.795000 轉(zhuǎn)換成 7 進制數(shù)為: 0.53645364
十進制正小數(shù) 0.795000 轉(zhuǎn)換成 8 進制數(shù)為: 0.62702436
十進制正小數(shù) 0.795000 轉(zhuǎn)換成 9 進制數(shù)為: 0.71348853
以下代碼提供了這個功能。其中,dTestNo表示待轉(zhuǎn)的十進制小數(shù)。iBase表示進制數(shù)。
#include <stdio.h>
void fun(double dTestNo, int iBase)
{
int iT[8]; //轉(zhuǎn)化后的小數(shù)保留8位數(shù)
int iNo;
printf("十進制正小數(shù) %f 轉(zhuǎn)換成 %d 進制數(shù)為: ",dTestNo, iBase);
for(iNo=0;iNo<8;iNo++) //分別得出每位數(shù)字 小數(shù)部分
{
dTestNo *= iBase;
iT[iNo] = (int)dTestNo; //得出整數(shù)部分存放起來
if(dTestNo>=1) dTestNo -= iT[iNo]; //減去整數(shù)部分
}
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");
}
相關(guān)文章
C++數(shù)據(jù)結(jié)構(gòu)之紅黑樹的實現(xiàn)
紅黑樹在表意上就是一棵每個節(jié)點帶有顏色的二叉搜索樹,并通過對節(jié)點顏色的控制,使該二叉搜索樹達到盡量平衡的狀態(tài)。本文主要為大家介紹了C++中紅黑樹的原理及實現(xiàn),需要的可以參考一下2022-08-08