C语言中二进制指定的某一位数0变1,或者1变0,并输出该数值.给个详细的代码吧!谢谢!!!

2025-05-15 07:56:35
推荐回答(4个)
回答1:

0变1其它位不变,位或一个该位为1其它位为0的数可得
1变0其它位不变,位与一个该位为0其它位为1的数可得
得到等N位为1其它位为0的数,可用1左移N位即得
得到等N位为0其它位为1的数,用前数位反一下即得

演示程序:
#include
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< }
else//清0
{
x1 = x0 & ~(1< }
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;
}

回答2:

int fun(int a,int x)
{
int c;
c=a|(1《x);
return c;
}
这里a是要操作的数,x是指定位(从右向左)

回答3:

#define set_bit(val,bit) \
do{\
val |= 1< }while(0)
#define clr_bit(val,bit)\
do{\
val &= ~(1< }while(0)

回答4:

最后一位1变0,0变1,
例如:32位下
int a;
printf("请输入a的值");
scanf("%d",&a);
a=a^1;
printf("%d",a);