#include <stdio.h>
#include <stdlib.h>
#include <math.h>
int main()
{
float n ,a, sum,count,count1;
printf("nInput integer in base 10 : ");
scanf("%f", &n);
for(count=0 ; count<=100 ; ++count){
if(n/pow(2,count)<2 && n/pow(2,count)>=1)break;
}
a=n-pow(2,count);
sum=pow(10,count);
for(count1=count-1 ; count1>=0 ; --count){
if(a/pow(2,count1)<2 && a/pow(2,count1)>=1 ){
a-=pow(2,count1);
sum+=pow(10,count1);
}
}
printf("The binary of %.0f is %.0f",n,sum);
return 0;
}
此代码用于打印小数号的二进制代码,而无需使用数组
@kiner_shah在评论您的问题的评论中所述,您的第二个循环中有一个不正确的变量。
for(count1=count-1 ; count1>=0 ; --count){
...
应该是
for(count1=count-1 ; count1>=0 ; --count1){
...
使用更独特的/描述性变量名称来避免单个字符错误是一个很好的习惯。