輸入一個十進制數 如-14.48 61.3585
輸出二進制數應為 -1110.0111101011 和 111101.0101101111
這是我編寫的程序
#include
//轉化為2進制
void z2(int n)
{
if (n > 1)
{
z2(n / 2);
}
printf("%d", n % 2);
}
void z21(float f,int c)
{
float twice;
int tmp;
if (c == 0)
return;
twice = f * 2;
tmp = (int)twice;
printf("%d", tmp);
z21(twice - tmp, --c);
}
void main()
{
float shu = 0;
int zhengshu = 0;
printf("請輸入一個十進制數:");
scanf("%f", &shu);
zhengshu = (int)shu;
shu -= zhengshu;
z211(zhengshu,shu);
}
我輸入 61.3585輸出111101.01011011 輸入 -14.48 輸出 0.0-1-1-1-10-10 結果都不對呀,如何改正??
保留幾位小數啊,你這些數都辦法准確顯示的