C语言中“二进制指定的某一位数0变1,或者1变0,并输出该数值”的代码是什么?
1个回答
展开全部
0变1其它位不变,位或一个该位为1其它位为0的数可得
1变0其它位不变,位与一个该位为0其它位为1的数可得
得到等N位为1其它位为0的数,可用1左移N位即得
得到等N位为0其它位为1的数,用前数位反一下即得
演示程序:
#include<stdio.h>
char*int2bin(int ,char* );
int main()
{
int x0,x1,n,flag;
char x0b[33]={0};
char x1b[33]={0};
while(1)
{
x0 = x1 = n = flag = -1;
printf("输入原始数值 操作位(0-31) 和操作方式(1置/0清)\n");
scanf("%d %d %d", &x0, &n, &flag);
if( n<0 || n>31 || flag!=0&&flag!=1 ) break;//无效输入将退出
if(flag==1)//置1
{
x1 = x0 | (1<<n); //n位置1
}
else//清0
{
x1 = x0 & ~(1<<n); //n位清0
}
printf("处理前十进制:%-10d 二进制:%s\n", x0,int2bin(x0,x0b));
printf("处理后十进制:%-10d 二进制:%s\n\n",x1,int2bin(x1,x1b));
fflush(stdin);
}
return 0;
}
char*int2bin(int x,char*out)
{
for(int i=0;i<32;i++)
out[i] = (x&(1<<(31-i))) ? '1' : '0';
out[32] = '\0';
return out;
}
1变0其它位不变,位与一个该位为0其它位为1的数可得
得到等N位为1其它位为0的数,可用1左移N位即得
得到等N位为0其它位为1的数,用前数位反一下即得
演示程序:
#include<stdio.h>
char*int2bin(int ,char* );
int main()
{
int x0,x1,n,flag;
char x0b[33]={0};
char x1b[33]={0};
while(1)
{
x0 = x1 = n = flag = -1;
printf("输入原始数值 操作位(0-31) 和操作方式(1置/0清)\n");
scanf("%d %d %d", &x0, &n, &flag);
if( n<0 || n>31 || flag!=0&&flag!=1 ) break;//无效输入将退出
if(flag==1)//置1
{
x1 = x0 | (1<<n); //n位置1
}
else//清0
{
x1 = x0 & ~(1<<n); //n位清0
}
printf("处理前十进制:%-10d 二进制:%s\n", x0,int2bin(x0,x0b));
printf("处理后十进制:%-10d 二进制:%s\n\n",x1,int2bin(x1,x1b));
fflush(stdin);
}
return 0;
}
char*int2bin(int x,char*out)
{
for(int i=0;i<32;i++)
out[i] = (x&(1<<(31-i))) ? '1' : '0';
out[32] = '\0';
return out;
}
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询