4. 题目:输入一个整数a,再输入两个整数p(p<32),v(0|1);
将该整数a的p位设置为v,输出修改后的该整数的二进制表示.
分析:先将二进制放入一个数组中,将其p位修改即可
下面是代码实现:
/*********************************************************
输入一个整数a,再输入两个整数p(p<32),v(0|1);
将该整数a的p位设置为v,输出修改后的该整数的二进制表示.
*********************************************************/
#include <stdio.h>
void Change_bit(int a, int p, int v)
{
int Arr[32] = {0};
int i = 0;
int count = 0;
for (i = 0; i < 32; i++)
{
Arr[i] = a % 2;
a >>= 1;
}
Arr[p - 1] = v; //p位设置为v
for (i = 31; i >=0; i--)
{
printf ("%d", Arr[i]);
count++;
if (count % 4 == 0)
{
printf (" ");
}
}
printf ("\n");
}
int main()
{
int a = 0;
int p = 0;
int v = 0;
printf ("please input a integer:");
scanf ("%d", &a);
printf ("please input p(0 < p < 32):");
scanf ("%d", &p);
printf ("please input v(0/1):");
scanf ("%d", &v);
Change_bit(a, p, v);
return 0;
}
输入一个整数a,再输入两个整数p(p<32),v(0|1);
将该整数a的p位设置为v,输出修改后的该整数的二进制表示.
*********************************************************/
#include <stdio.h>
void Change_bit(int a, int p, int v)
{
int Arr[32] = {0};
int i = 0;
int count = 0;
for (i = 0; i < 32; i++)
{
Arr[i] = a % 2;
a >>= 1;
}
Arr[p - 1] = v; //p位设置为v
for (i = 31; i >=0; i--)
{
printf ("%d", Arr[i]);
count++;
if (count % 4 == 0)
{
printf (" ");
}
}
printf ("\n");
}
int main()
{
int a = 0;
int p = 0;
int v = 0;
printf ("please input a integer:");
scanf ("%d", &a);
printf ("please input p(0 < p < 32):");
scanf ("%d", &p);
printf ("please input v(0/1):");
scanf ("%d", &v);
Change_bit(a, p, v);
return 0;
}