每日一题(小白)模拟娱乐篇13

今天题目比较简单,直接分析。小蓝想知道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);
				
	}
相关推荐
肖哥弹架构1 分钟前
Spring JDBCTemplate 十大性能优化秘籍:从慢如蜗牛到快如闪电!
java·后端·程序员
苦学编程的谢4 分钟前
MyBatis_3
java·开发语言·后端·mybatis
小新学习屋19 分钟前
《剑指offer》-数据结构篇-树
数据结构·算法·leetcode
好心的小明25 分钟前
【深度之眼机器学习笔记】04-01-决策树简介、熵,04-02-条件熵及计算举例,04-03-信息增益、ID3算法
笔记·算法·决策树
fouryears_2341740 分钟前
什么是JSON,如何与Java对象转化
java·spring boot·spring·json
CHEN5_021 小时前
【RocketMQ】一分钟了解RocketMQ
java·rocketmq·java-rocketmq
寒士obj1 小时前
JVM 内存结构
java·开发语言·jvm
带刺的坐椅1 小时前
Solon 整合 LiteFlow 规则引擎:概念与实战
java·solon·liteflow
wuk9982 小时前
互联网应用主流框架整合 Spring Boot开发
java·spring boot·后端
恣艺2 小时前
LeetCode 1074:元素和为目标值的子矩阵数量
算法·leetcode·矩阵