标签:selected int 明解 pos C语言 入门篇 xx printf bits
/*
编写set函数,返回将无符号整数x的第pos位设为1后的值
编写reset函数,返回将无符号整数x的第pos位设为0后的值
编写inverse函数,返回将无符号整数x的第pos位取反后的值
*/
#include <stdio.h>
int count_bits(unsigned x)
{
int bits = 0;
while (x)
{
if (x & 1U) bits++;
x >>= 1;
}
return bits;
}
int int_bits()
{
return count_bits(~0U);
}
void print_bits(unsigned x)
{
int i;
for (i = int_bits() - 1; i >= 0; i--)
putchar(((x >> i) & 1U) ? '1' : '0');
}
unsigned set(unsigned x, int pos)
{
return x | 1U << pos - 1;
}
unsigned reset(unsigned x, int pos)
{
return x & ~(1U << pos - 1);
}
unsigned inverse(unsigned x, int pos)
{
return x ^ 1U << pos - 1;
}
int main()
{
unsigned xx;
int x_pos, selected;
printf("1>>>某一位设为1\n2>>>某一位设为0\n3>>>某一位取反\n请选择对应的数字:");
scanf("%d", &selected);
printf("请输入一个非负整数:"); scanf("%u", &xx);
if (selected == 1)
printf("请输入第几位设为1:");
else if (selected == 2)
printf("请输入第几位设为0:");
else
printf("请输入第几位取反:");
scanf("%d", &x_pos);
printf("更改前:");
print_bits(xx);
putchar('\n');
printf("更改后:");
if (selected == 1)
print_bits(set(xx, x_pos));
else if (selected == 2)
print_bits(reset(xx, x_pos));
else
print_bits(inverse(xx, x_pos));
return 0;
}
标签:selected,int,明解,pos,C语言,入门篇,xx,printf,bits 来源: https://blog.csdn.net/qq_40651285/article/details/113829590
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。