
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner in = new Scanner(System.in);
int num = in.nextInt(); //读取数字
int n = 0; //计数变量
for (int i = 0; i < 32; i++) {
if ((num & 1) == 1) {
//如果末位为1则计数
n++;
}
//无符号右移
num = num >> 1;
}
System.out.println(n);
}
}
本文介绍了一个Java程序,用于计算输入整数中二进制表示下1的个数。通过使用位操作和循环,该程序可以高效地解决这个问题。

被折叠的 条评论
为什么被折叠?



