今天题目比较简单,直接分析。小蓝想知道2024这个数字中有几个1,计算机组成学习好的同学肯定可以直接长除法或者瞪眼法得出答案:
2024=11111101000(B)也就是说2024中有一共有六个1
接下来用代码实现 ,我们也可以看出其中的有效数字为2,2,4;判断出2和4的二进制包含几个1就可以,先将数字转换为二进制,然后判断2024二进制包含几位1,输出即可。
代码实现👇
System.out.println(Integer.bitCount(2024));//瞪眼法
bitCount(int i) 函数,实现统计一个数的二进制位有多少个 1
public static void main(String[] args) {
Scanner scanner =new Scanner(System.in);
int i=2024;
String binaryString = Integer.toBinaryString(i);
int count=0;
for (int j = 0; j < binaryString.length(); j++) {
if (binaryString.charAt(j)=='1') {
count++;
}
}
System.out.println(count);
scanner.close();
}
转换法
public static void main(String[] args) {
Scanner scanner =new Scanner(System.in);
int i=2024;
int count=0;
while (i>0) {
if (i%2!=0) {//二进制就是2的多少次方
count++;
}
i/=2;
}
System.out.println(count);
}
自己写方法
public static void main(String[] args) {
Scanner scanner =new Scanner(System.in);
int i=2024;
int count=0;
while (i>0) {
count+=i%2;//与长除法类似,利用长除法的原理
i/=2;
}
System.out.println(count);
}