輸入一個十進制數 如-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 結果都不對呀,如何改正??
我稍微修改了一下,可以參考參考
#include <stdio.h>
//轉化為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);
}
int main()
{
float shu = 0;
int zhengshu = 0;
printf("請輸入一個十進制數:");
scanf("%f", &shu);
if (shu < 0)//為負數
{
printf("-");//打印負號
shu = abs(shu);//取絕對值
}
zhengshu = (int)shu;
shu -= zhengshu;
z2(zhengshu);//計算並打印整數部分
printf(".");//打印小數點
z21(shu, 10);//計算並打印小數部分,第二個參數10為你想要計算的小數點後的位數,比如說10,則小數點後算10位
return 0;
}
結果: