函数返回参数二进制中1的个数

本文介绍了四个实用的二进制操作技巧:计算整数中1的个数、获取并输出整数二进制中的奇偶数位序列、按位逐个输出整数的每一位以及比较两个整数二进制表示的不同位数。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.函数返回参数二进制中1的个数

#include<stdio.h>
int count_one_bits(unsigned int value)
{
 int num=0;
 while (value)
 {
  if ((value&1)== 1)
   num++;
  value>>=1;
 }
 return num;
}
int main()
{
 int i;
 int num;
 printf("请输入");
 scanf_s("%d",&i);
 num = count_one_bits(i);
 printf("%d\n", num);
 system("pause");
 return 0;
}


2.获取一个数二进制序列中所以偶数和奇数位,分别输出二进制序列

#include<stdio.h>
int main()
{
 int num = 0;
 int i = 0;
 scanf_s("%d", &num);
 printf("奇数序列");
 for (i = 31; i >= 0; i = i - 2)
 {
  printf("%d", (num >> i) & 1);
 }
 printf("\n");
 printf("偶数序列");
 for (i = 30; i >= 0; i = i - 2)
 {
  printf("%d", (num >> i) & 1);
 }
 printf("\n");
 system("pause");
 return 0;
}

3.输出一个整数的每一位

#include<stdio.h>
int main()
{
 int i=0 ;
 int a;
 printf("请输入");
  scanf_s("%d", &i);
  while (i > 0)
  {
   a = i % 10;
   i = i / 10;
   printf("%d\n", a);
  }
  system("pause");
  return 0;
}

4.两个int整数m和n的二进制表达中,有多少个位不同

#include<stdio.h>
int differ_num_of_bit(int m, int n)
{
 int num = 0;
 int i = 0;
 num = m^n;
 while (num)
 {
  i++;
  num = num&(num - 1);
 }
 return i;
}
 int main()
 {
  int a, b, c;
  scanf_s("%d%d", &a, &b);
  c = differ_num_of_bit(a, b);
  printf("%d\n", c);
  system("pause");
  return 0;
 }

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值