《C Primer Plus》上通过使用位运算显示二进制数的方法。有改动。
#include<stdio.h>
char*itobs(int n,char*ps);
void show_bstr(char*str);
int main()
{
char bin_str[8*sizeof(int)+1]; //定义一个足以存放二进制字符串的数组
int number;
while(scanf("%d",&number)==1)
{
itobs(number,bin_str);
printf("%d is ",number);
show_bstr(bin_str);
putchar('\n');
}
return 0;
}
char*itobs(int n,char*ps) //化为二进制
{
int i;
static int size=8*sizeof(int);
for(i=size-1;i>=0;i--,n>>=1)
ps[i]=(01&n)+'0'; //数字转化成字符+'0' ,字符转化成数字 -'0'
ps[size]='\0';
return ps;
}
void show_bstr(char*str) //4位一组显示二进制字符串
{
int i=0;
while(str[i]) //不是一个空字符
{
putchar(str[i]);
if(++i%4==0&&str[i])
putchar(' ');
}
}
|