使用位运算显示二进制数

《C Primer Plus》上通过使用位运算显示二进制数的方法。有改动。

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

你可能感兴趣的:(位运算,C语言,二进制)