【C语言】求一个整数的二进制序列中1的个数的三种方法

简介: 【C语言】求一个整数的二进制序列中1的个数的三种方法

方法一:逐位%2法

该方法的初步测试代码如下:

int NumberOf1(int n) 
{
  int count = 0;
  while (n)
  {
        if (n % 2 == 1)
      {
       count++;
      }
          n = n / 2;
  }
  return count;
}

原理图解:

该方法图解如下:

测试运行:

原理图解如上,接下来运行测试一下:

测试正数:输入15

测试0:输入0

可以看到,程序测试非负数都是没有问题的,但是当测试到负数时就会这样:

测试负数:输入-6

可以看到,正数和0的测试都没有问题,但是负数却显示为0,我们来看看问题出在哪里了:

强制转换后函数代码如下:

int NumberOf1(unsigned int n) 
{
  int count = 0;
  while (n)
  {
        if (n % 2 == 1)
      {
       count++;
      }
          n = n / 2;
  }
  return count;
}

测试运行:

强制转换可以实现的原理是:


 方法二:逐位&1法

该方法的初步测试函数代码如下:

int NumberOf1(int n)
{
  int i = 0;
  int count = 0;
  for (i = 0; i <32; i++)
  {
    if (n >> i & 1 == 1)
    {
      count++;
    }
  }
  return count;
}

原理图解:

该方法原理图解如下:

测试运行:

测试正数:输入15

测试0:输入0

测试负数:输入-7

输出结果均正确,该方法可行。


方法三:n&(n-1)法

该方法的初步测试代码如下:

int NumberOf1(int n)
{
  int count = 0;
  while (n)
  {
    n=n& (n - 1);
    count++;
  }
  return count;
}

原理图解:

该方法原理图解如下:

测试运行:

原理如上,测试运行:

测试正数:输入11

测试0:输入0

测试负数:输入-11

输出结果均正确,该方法可行。


今日感悟:学而不思则罔,思而不学则殆!


相关文章
|
19天前
|
存储 网络协议 算法
【C语言】进制转换无难事:二进制、十进制、八进制与十六进制的全解析与实例
进制转换是计算机编程中常见的操作。在C语言中,了解如何在不同进制之间转换数据对于处理和显示数据非常重要。本文将详细介绍如何在二进制、十进制、八进制和十六进制之间进行转换。
29 5
|
23天前
|
传感器 人工智能 物联网
C 语言在计算机科学中尤其在硬件交互方面占据重要地位。本文探讨了 C 语言与硬件交互的主要方法,包括直接访问硬件寄存器、中断处理、I/O 端口操作、内存映射 I/O 和设备驱动程序开发
C 语言在计算机科学中尤其在硬件交互方面占据重要地位。本文探讨了 C 语言与硬件交互的主要方法,包括直接访问硬件寄存器、中断处理、I/O 端口操作、内存映射 I/O 和设备驱动程序开发,以及面临的挑战和未来趋势,旨在帮助读者深入了解并掌握这些关键技术。
40 6
|
2月前
|
Java 编译器 C语言
【一步一步了解Java系列】:Java中的方法对标C语言中的函数
【一步一步了解Java系列】:Java中的方法对标C语言中的函数
30 3
|
6月前
|
存储 C语言
【C语言刷题系列】求一个数组中两个元素a和b的和最接近整数m
【C语言刷题系列】求一个数组中两个元素a和b的和最接近整数m
|
6月前
|
IDE 编译器 开发工具
详细解读C语言程序设计:现代方法(第2版)第二章全部习题答案
详细解读C语言程序设计:现代方法(第2版)第二章全部习题答案
46 0
|
6月前
|
C语言
【C语言刷题系列】交换整数的奇数位和偶数位
【C语言刷题系列】交换整数的奇数位和偶数位
|
6月前
|
存储 C语言
【C语言进阶篇】整数在内存的存储——原码、反码、补码
【C语言进阶篇】整数在内存的存储——原码、反码、补码
|
19天前
|
存储 C语言 开发者
【C语言】字符串操作函数详解
这些字符串操作函数在C语言中提供了强大的功能,帮助开发者有效地处理字符串数据。通过对每个函数的详细讲解、示例代码和表格说明,可以更好地理解如何使用这些函数进行各种字符串操作。如果在实际编程中遇到特定的字符串处理需求,可以参考这些函数和示例,灵活运用。
39 10
|
19天前
|
存储 程序员 C语言
【C语言】文件操作函数详解
C语言提供了一组标准库函数来处理文件操作,这些函数定义在 `<stdio.h>` 头文件中。文件操作包括文件的打开、读写、关闭以及文件属性的查询等。以下是常用文件操作函数的详细讲解,包括函数原型、参数说明、返回值说明、示例代码和表格汇总。
42 9