这是我的代码,我认为shift运算符有问题,我在嵌入式软件中使用了它们,但是我不知道是否可以在普通代码上使用它们,我编写了代码来实现相同的目的,但是加(2 * 10 ^ digit)的方法,但使用shifts似乎容易得多-如果可能的话,请帮助:
#include <stdio.h>
#include <stdlib.h>
#include <math.h>
double find_power(double x);
int main()
{
double bin=00000000, dec , k ;
printf("enter decimal number:\n");
scanf("%d",&dec);
for(;;)
{
k=find_power(dec);
bin|=(1<<k);
dec-=pow(2,k);
if(dec==1)
{
bin|=(1<<0);
break;
}
else if(dec==0)
{
bin&=(~(1<<0));
break;
}
}
printf("%d",bin);
return 0;
}
double find_power(double x)
{
double i=1,j=0;
for(;;)
{
i*=2;
if(x>=i)
{
j++;
}
else if(x<i)
{
break;
}
}
return j;
}
最佳答案
您在整个代码中疯狂地混合了double
和int
。您尝试使用scanf将int
读取到double
中,这会调用未定义的行为。然后尝试将double
变量与按位运算符一起使用,这很可能毫无意义。您将要使用已知大小的无符号整数。
您应该启用/监听编译器警告。