打印整数二进制的奇数位和偶数位
1.题目
获取一个整数二进制序列中所有的偶数位和奇数位,分别打印出二进制序列
2.题目分析
打印一个整数的二进制位中的偶数位和奇数位,可以对整数进行移位操作,再将移位的二进制位与1进行&操作。
按位&,同为1则为1,不同为1时则为0。
如:
//0000 0000 0000 0000 0000 0000 0000 0001
//0000 0000 0000 0000 0000 0000 1100 0111 199
如这个数,对这个数进行移位操作,每移一位就可得到这个数的二进制位。但是我们需要的是,偶数位和奇数位进行分别输出,所以就需要每一次移两位。
3.函数实现
void Print(int n)
{int i = 31;printf("二进制位:");while (i >= 0){printf("%d ", (n >> i) & 1);i--;}printf("\n");printf("奇数位:");for (i = 30; i >= 0; i-=2){printf("%d ", (n >> i) & 1);}printf("\n");printf("偶数位:");for (i = 31; i >= 1; i -= 2){printf("%d ", (n >> i) & 1);}printf("\n");
}
4.实际代入
#include<stdio.h>
void Print(int n)
{int i = 31;printf("二进制位:");while (i >= 0){printf("%d ", (n >> i) & 1);i--; //此处是使结果正向打印}printf("\n");printf("奇数位:");for (i = 30; i >= 0; i-=2) //此处是使结果正向打印{printf("%d ", (n >> i) & 1);}printf("\n");printf("偶数位:");for (i = 31; i >= 1; i -= 2) //此处是使结果正向打印{printf("%d ", (n >> i) & 1);}printf("\n");
}
int main() //获取一个整数二进制序列中所有的偶数位和奇数位,分别打印出二进制序列
{int a = 0;scanf("%d", &a);Print(a);return 0;
}