前言
本文是关于整数二进制的练习,获取一个整数二进制序列中所有的偶数位和奇数位,分别打印出二进制序列
例如:
十进制:3
二进制:00000000 00000000 00000000 00000011
奇数位: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1
偶数位:0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1
1、方法1
自己写的很罗嗦,不简洁,但是也实现了题目的要求:
int main()
{
int a = 3;
int arr1[32] = { 0 };
//int arr2[32] = { 0 };
int cnt1 = 0;
for (int i = 0; i < 32; i++)
{
if (i%2==0)//偶数
{
if (a&(1<<i))//按位与1, 非0则 对应位是1
{
arr1[i] = 1;
}
else //对应位是0
{
arr1[i] = 0;
}
}
else//奇数
{
if (a&(1 << i))//按位与1, 非0则 对应位是1
{
arr1[i] = 1;
}
else
{
arr1[i] = 0;
}
}
}
printf("奇数位:");
for (int i = 31; i >= 1; i -= 2)//奇数
{
printf("%d ", arr1[i]);
}
printf("\n");
printf("偶数位:");
for (int i = 30; i >= 0; i-=2)//偶数
{
printf("%d ", arr1[i]);
}
return 0;
}
结果见下图:
2、改进方法1
方法1 根本不需要判断每位是什么,直接输出就行,
int main()
{
int a = 3;
printf("奇数位:");
for (int i = 31; i >= 1; i -= 2)//奇数
{
printf("%d ", (a >> i) & 1);//这样是判断每一位
//printf("%d ", a &(1<< i));这是错误的
}
printf("\n");
printf("偶数位:");
for (int i = 30; i >= 0; i -= 2)//偶数
{
printf("%d ", (a >> i) & 1);
//printf("%d ", a &(1 << i));
}
return 0;
}
结果见下图:
总结
还是需要多练习,不管自己写的代码是罗嗦了,还是太烂了,也必须要写完,实现题目要求,这是最重要的一步。
第二步就是多看看别人写的代码,学习别人的思路。