算法题 — 整数转二进制,查找其中1的数量

简介: 算法题 — 整数转二进制,查找其中1的数量

 

题目

请实现一个函数(不限语言),输入一个整数,输出该数二进制表示中 1 的个数。例如,把 9 表示成二进制是 1001,有 2 位是 1。因此,如果输入 9,则该函数输出 2。

public class CountOnes {
    public static int countOnes(int num) {
        int count = 0;
        while (num != 0) {
            // 如果当前位为1,计数器加1
            if ((num & 1) == 1) {
                count++;
            }
            // 将数字右移一位,继续检查下一位
            num = num >>> 1; // 无符号右移
        }
        return count;
    }
 
    public static void main(String[] args) {
        int num = 9; //1001
        System.out.println(+ num + "中有 : " + countOnes(num)+"个1"); 
    }
}


详细解读


  1. public class CountOnes {: 这行代码定义了一个名为 CountOnes 的公共类。
  2. public static int countOnes(int num) {: 这行代码定义了一个静态方法 countOnes,用于计算给定整数 num 中包含的二进制表示中的1的个数。它采用一个整数作为输入参数,并返回一个整数作为1的个数。
  3. int count = 0;: 这行代码声明了一个名为 count 的整数变量,用于记录1的个数。初始值为0。
  4. while (num != 0) {: 这行代码开始一个 while 循环,条件是 num 不等于0,即当 num 的二进制表示还有位时,继续执行循环。
  5. if ((num & 1) == 1) {: 这行代码检查 num 的最低位是否为1,它通过使用按位与运算符 & 和二进制数 1 来实现。如果最低位是1,则条件成立,计数器 count 增加1。
  6. num = num >>> 1;: 这行代码将 num 右移一位。>>> 是无符号右移操作符,它将 num 的所有位向右移动一位,并用0填充最高位。
  7. return count;: 这行代码返回计数器 count 的值,即1的个数。
  8. public static void main(String[] args) {: 这行代码定义了主方法 main。
  9. int num = 9; //1001: 这行代码声明并初始化了一个名为 num 的整数变量,赋值为9。在二进制中,9表示为1001。
  10. System.out.println(+ num + "中有 : " + countOnes(num)+"个1");: 这行代码调用 countOnes 方法来计算 num 中1的个数,并将结果打印到控制台。
相关文章
|
6月前
|
自然语言处理 Rust 算法
【算法】13. 罗马数字转整数(多语言实现)
罗马数字包含以下七种字符: I, V, X, L,C,D 和 M。 | 字符 | 数值 | |--|--| | I | 1 | | V | 5 | | X | 10 | | L | 50 | | C | 100 | | D | 500 | | M | 1000 | 例如, 罗马数字 2 写做 II ,即为两个并列的 1。12 写做 XII ,即为 X + II 。 27 写做 XXVII, 即为 XX + V + II 。 通常情况下,罗马数字中小的数字在大的数字的右边。但也存在特例,例如 4 不写做 IIII,而是 IV。数字 1 在数字 5 的左边,所表示的数等于大数 5 减小数 1
【算法】13. 罗马数字转整数(多语言实现)
|
6月前
|
算法 测试技术 C#
【数位dp】【C++算法】600. 不含连续1的非负整数
【数位dp】【C++算法】600. 不含连续1的非负整数
|
6月前
|
算法 Java
[Java·算法·简单] LeetCode 13. 罗马数字转整数 详细解读
[Java·算法·简单] LeetCode 13. 罗马数字转整数 详细解读
63 0
|
3月前
|
人工智能 算法
第一周算法设计与分析:C : 200和整数对之间的情缘
这篇文章介绍了解决算法问题"200和整数对之间的情缘"的方法,通过统计数组中每个数模200的余数,并计算每个同余类中数的组合数来找出所有满足条件的整数对(i, j),使得\( A_i - A_j \)是200的整数倍。
|
4月前
|
算法
【算法】二分查找(整数二分和浮点数二分)
算法学习——二分查找(整数二分和浮点数二分)
43 0
【算法】二分查找(整数二分和浮点数二分)
|
4月前
|
机器学习/深度学习 算法 计算机视觉
通过MATLAB分别对比二进制编码遗传优化算法和实数编码遗传优化算法
摘要: 使用MATLAB2022a对比了二进制编码与实数编码的遗传优化算法,关注最优适应度、平均适应度及运算效率。二进制编码适用于离散问题,解表示为二进制串;实数编码适用于连续问题,直接搜索连续空间。两种编码在初始化、适应度评估、选择、交叉和变异步骤类似,但实数编码可能需更复杂策略避免局部最优。选择编码方式取决于问题特性。
|
4月前
|
算法
Ngnix02 --- Ngnix的功能特性及常见功能,Ngnix常用的功能模块,有不同算法,根据不同算法进行转发,ip_hash、url_hash、fair,核心组成 ngnix二进制可执行文件
Ngnix02 --- Ngnix的功能特性及常见功能,Ngnix常用的功能模块,有不同算法,根据不同算法进行转发,ip_hash、url_hash、fair,核心组成 ngnix二进制可执行文件
|
5月前
|
算法 Java Go
【经典算法】LeetCode 67. 二进制求和(Java/C/Python3/Golang实现含注释说明,Easy)
【经典算法】LeetCode 67. 二进制求和(Java/C/Python3/Golang实现含注释说明,Easy)
65 2
|
5月前
|
算法
【经典LeetCode算法题目专栏分类】【第4期】BFS广度优先算法:单词接龙、最小基因变化、二进制矩阵中的最短路径
【经典LeetCode算法题目专栏分类】【第4期】BFS广度优先算法:单词接龙、最小基因变化、二进制矩阵中的最短路径
|
6月前
|
算法 C语言
【C语言】求最小新整数(贪心算法)
【C语言】求最小新整数(贪心算法)
75 1