问题:
1.输入int 20,其二进制为10100,按位输出10100;
2.或者将1转化为“+”,0转化为“-”,输出就是” + - + - - “;
int biTofh(int bi,int len){//二进制转化为正负号
int i=;
while(i<len){
int tmp = ;
if((bi & (tmp<<(len-i-))) != ){//从最左位开始比较,该位是1
printf(" + ");
}
else{
printf(" - ");
}
i++;
}
printf("\n");
return ;
} int main(){
int input[] = {,,,,};
biTofh(,);
return ;
}
输出结果:
xu@xu-ThinkPad-X61:~/algorithm$ ./a.out
+ - + - -
xu@xu-ThinkPad-X61:~/algorithm$
真厉害啊