C语言:获取一个整数二进制序列中所有的偶数位和奇数位,分别打印出二进制序列

解题思路:打印一个整数的二进制位中的偶数位和奇数位,可以对整数进行移位操作,再将移位的二进制位与1进行&操作。

按位&,同为1则为1,不同为1时则为0。

如:

//0000 0000 0000 0000 0000 0000 0000 0001
//0000 0000 0000 0000 0000 0000 1100 0111   199

如这个数,对这个数进行移位操作,每移一位就可得到这个数的二进制位。但是我们需要的是,偶数位和奇数位进行分别输出,所以就需要每一次移两位。

#include <stdio.h>
#include <Windows.h>
#pragma warning(disable:4996)
#include <time.h>
#include <stdlib.h>
void All1(int m);

int main()
{
    
    
	int x = 199;
	All1(x);
	return 0;
}

void All1(int m)
{
    
    
	int i = 0;
	i = 31;
	printf("二进制:");
	while (i >= 0)
	{
    
    
		printf("%d ", (m >> i) & 1);
		i--;
	}
	printf("\n奇数位:");
	for (i = 0; i <=30; i += 2)
	{
    
    
		printf("%d ", (m >> i) & 1);
	}
	printf("\n偶数位:");
	for (i = 1; i <= 31; i += 2)
	{
    
    
		printf("%d ", (m >> i) & 1);
	}
	printf("\n");
}

输出结果为:
在这里插入图片描述
这是先从低位向右移位,但这样不利于观看,做一点优化。
先对整个数进行移位。偶数位第一次移31位,每次减2。奇数位第一次移30位,每次减2。

#include <stdio.h>
#include <Windows.h>
#pragma warning(disable:4996)
#include <time.h>
#include <stdlib.h>
void All(int m);

int main()
{
    
    
	int x = 199;
	All(x);
	return 0;
}

void All(int m)
{
    
    
	int i = 0;
	i = 31;
	printf("二进制:");
	while (i>=0)
	{
    
    
		printf("%d ", (m >> i) & 1);
		i--;
	}
	printf("\n奇数位:");
	for (i = 30; i >= 0; i -= 2)
	{
    
    
		printf("%d ", (m >> i) & 1);
	}
	printf("\n偶数位:");
	for (i = 31; i >= 1; i -= 2)
	{
    
    
		printf("%d ", (m >> i) & 1);
	}

}

结果为:
在这里插入图片描述

猜你喜欢

转载自blog.csdn.net/w903414/article/details/105749564
今日推荐