一、

#include<stdio.h>
int main()
{
int a,i,j,m;
int arr[32]={0};
printf("输入一个整数:\n");
scanf("%d",&a);
printf("二进制数为:\n");
for(i=0;i<32;i++)
{
m=a%2;
j=a/2;
a=j;
arr[i]=m;
}
for(i=32;i>=0;i--)
{
printf("%d",arr[i]);
if(i%4==0)
printf(" ");
}
printf("\n");
printf("偶数序列:");

for(i=31;i>=0;i-=2)
{
printf("%d",arr[i]);
}
printf("\n");
printf("奇数序列:");
for(i=30;i>=0;i-=2)
{
printf("%d",arr[i]);
}
printf("\n");
return 0;
}

二、

#include<stdio.h>
int main()
{
 int value;
 int i = 0;
 int arr1[16];
 int arr2[16];
 scanf("%d",&value);
 while (i < 32)
 {
  arr1[i/2] = value % 2;
  value = value >> 1;
  i++;
  arr2[(i-1)/2] = value % 2;
  value = value >> 1;
  i++;
 }
 printf("奇数序列");
 for(i=15;i>=0;i--)
 printf("%d",arr1[i]);
 printf("\n");
 printf("偶数序列");
 for(i=15;i>=0;i--)
 printf("%d",arr2[i]);
 printf("\n");
return 0;
}

三、优化

#include<stdio.h>
int main()
{
    int value;
 int i=0;
 scanf("%d",&value);
 printf("偶数序列");
 for(i=0;i<32;i+=2)
 { 
  printf("%d",(value>>(31-i)&1));
    } 
 printf("\n"); 
      printf("奇数序列");
 for(i=0;i<32;i+=2)
 { 
  printf("%d",(value>>(30-i)&1));
    }
  printf("\n"); 


 return 0;
}