分别输出一个数的奇数位和偶数位的二进制序列

思路


这里写图片描述

通过观察我们可以发现可以通过移位操作实现奇数位序列和偶数位序列的输出
(1)奇数序列:每次右移奇数位然后&1,可以依次输出。
(2)偶数序列:每次右移偶数位然后&1,可以依次输出。
(3)这样都是逆序输出的,我们在代码中奇数从31位,偶数从30位开始移位即可。

代码实现



    #include <stdio.h>

    int main()
    {
        int num = 0;
        int i = 0;
        printf("please enter a num:\n");
        scanf("%d",&num);
        printf("奇数序列为:\n");
        for(i=31; i>=0; i-=2)
        {
            printf("%d",(num >> i) & 1);//每次右移奇数位输出
            if((i+7) % 8 == 0)//每四个打印一个空格方便观察
            {
                printf(" ");
            }
        }
        printf("\n");
        printf("偶数序列为:\n");
        for(i=30; i>=0; i-=2)
        {
            printf("%d",(num >> i) & 1);//每次右移偶数位输出
            if((i+8) % 8 == 0)//每四个打印一个空格方便观察
            {
                printf(" ");
            }
        }
        printf("\n");
        return 0;
    }

效果截图

这里写图片描述

猜你喜欢

转载自blog.csdn.net/lzhcr123/article/details/79926464