c语言位操作、左移、右移、与、或、异或
/*
写一个函数返回参数二进制中 1 的个数
比如: 15 0000 1111 4 个 1
程序原型:
int count_one_bits(unsigned int value)
{
// 返回 1的位数
}
*/
#include <stdio.h>
#include <stdlib.h>
int count_one_bits(unsigned int value)
{
int i = 0;
while (value != 0){
i++;
value /= 2;
}
return i;
}
int main(){
printf("%d\n", count_one_bits(15));
system("pause");
return 0;
}
#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <stdlib.h>
int main(){
/*
2.获取一个数二进制序列中所有的偶数位和奇数位,
分别输出二进制序列。
*/
int i;
scanf("%d", &i);
int odd = 0;
int even = 0;
while (i != 0){
if ((i & 1 )== 0){
++even;
}
else{
++odd;
}
i /= 2;
}
printf("奇数个数=%d,偶数个数=%d\n", even, odd);
system("pause");
return 0;
}
#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <stdlib.h>
void print_num(int i){
if (i <= 0){
return;
}
print_num(i / 10);
printf("%d\n", i % 10);
}
int main(){
//3. 输出一个整数的每一位。
int i;
scanf("%d", &i);
print_num(i);
system("pause");
return 0;
}
#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <stdlib.h>
int diff_bit(int m,int n){
int count = 0;
while (m!=0||n!=0){
if ((m & 1) != (n & 1)){
count++;
}
m /= 2;
n /= 2;
printf("%d %d\n", m, n);
}
return count;
}
int main(){
/*
4.编程实现:
两个int(32位)整数m和n的二进制表达中,有多少个位(bit)不同?
输入例子:
1999 2299
输出例子:7
*/
int m, n;
scanf("%d %d", &m, &n);
printf("%d\n",diff_bit(m, n));
system("pause");
return 0;
}
重点添加了调试过程