一、
#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;
}
输出一个数的二进制数的奇数序列和偶数序列(三种方法)
最新推荐文章于 2023-03-20 23:02:48 发布