题解 | #求int型正整数在内存中存储时1的个数#
求int型正整数在内存中存储时1的个数
https://www.nowcoder.com/practice/440f16e490a0404786865e99c6ad91c9
import java.util.Scanner; // 注意类名必须为 Main, 不要有任何 package xxx 信息 public class Main { public static void main(String[] args) { Scanner in = new Scanner(System.in); // 注意 hasNext 和 hasNextLine 的区别 if (in.hasNextInt()) { int a = in.nextInt(); System.out.println(getOneNum(a)); } } public static int getOneNum(int num) { int i = 0; int ans = 0; while (1 << i <= num) { if (1 << (i + 1) > num) { ans++; num = num - (1 << i); i = 0; } else i++; } return ans; } }