//问题:
将一个浮点型的数转换为二进制
思路:拆分为整数和小数两部分
分别将整数部分和小数部分转换为2进制
//输入数据
double getDouble(){
double num;
printf(“请输入一个浮点型的数据:”);
scanf("%lf",&num);
return num;
}
//小数部分的长度
int getLen(){
int len;
printf(“小数部分需要保留的位数:”);
scanf("%d",&len);
return len;
}
//浮点数的整数部分
void getInt( int value){
int array[50];
int index=0;
while(value>0){
array[index++]=value%2;
value/=2;
}
//将二进制数组反向输出(除二取余)
while(index){
index–;
printf("%d",array[index]);
}
}
//浮点数的小数部分此处正向输出(乘二取整)
void getDecimal(double value,int len){
int array[len],index=0;
while(value!=0&&index<len){
value*=2;
array[index++]=(int)value;<