输入一个整数a,再输入两个整数p(p<32),v(0|1),将该整数a的p位设置为v,输出修改后的该整数的二进制表示.
#include <stdio.h>
void bin(int n); //输出二进制函数
int main()
{
int a, p, v;
int mask = 1;
printf("enter a number:");
scanf("%d",&a);
printf("enter p(p < 32):");
scanf("%d",&p);
printf("enter v(0 or 1):");
scanf("%d",&v);
printf("former binary is:\n");
bin(a);
printf("\n");
mask <<= (p - 1); //标志位
if(v == 1)
{
a = a | mask; //用或运算可以将需要的位置1
}
else
{
mask = ~mask; //用~运算符简介创造一个数,用&运算可以将需要的位置0
a = a & mask;
}
printf("latter binary is:\n");
bin(a);
printf("\n");
return 0;
}
void bin(int n)
{
int r;
r = n % 2;
if(n >= 2)
{
bin(n / 2);
}
putchar('0' + r);
}
void bin(int n); //输出二进制函数
int main()
{
int a, p, v;
int mask = 1;
printf("enter a number:");
scanf("%d",&a);
printf("enter p(p < 32):");
scanf("%d",&p);
printf("enter v(0 or 1):");
scanf("%d",&v);
printf("former binary is:\n");
bin(a);
printf("\n");
mask <<= (p - 1); //标志位
if(v == 1)
{
a = a | mask; //用或运算可以将需要的位置1
}
else
{
mask = ~mask; //用~运算符简介创造一个数,用&运算可以将需要的位置0
a = a & mask;
}
printf("latter binary is:\n");
bin(a);
printf("\n");
return 0;
}
void bin(int n)
{
int r;
r = n % 2;
if(n >= 2)
{
bin(n / 2);
}
putchar('0' + r);
}