《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(' '); } }