二进制中1的个数 3种解题思路与代码实现

6 篇文章 0 订阅
3 篇文章 0 订阅

二进制中1的个数

题目描述: 请实现一个函数,输入一个整数,输出该数二进制表示中1的个数。例如把9表示成二进制是1001,有2位是1。因此如果输入9,该函数输出2。

解法思路1: 整数int 有32位 循环32次,每次1左位移i次然后与整数N 与 运算,如果为i<<i本身,则N该位数为1

解法思路2: 整数N每次向右移1位,移动32次,每次与1 与 运算,如果为0,则该位为1

解法思路3: 消除法: 整数N每次减1 整数N & 整数(N-1) 结果不为0,则结果继续减1,等于0为结束,一共减的次数为1的总个数

深化运用解题思路3:用一条语句判断整数是否为2的整数次方
解题思路: 判断整数中只含有1个1 (N & (N - 1)) == 0

package com.miao.day01;

import java.util.Scanner;

//二进制中1的个数
public class BinaryNumberOfOne {

	public BinaryNumberOfOne() {
		// TODO Auto-generated constructor stub
	}
	public static void main(String[] args) {
		//声明需要处理的数字N
		int N;
		
		//初始化N
		System.out.print("请输入整数:");
		Scanner scan = new Scanner(System.in);
		N = scan.nextInt();
		
		//1的总数
		int total1 = 0;
		//解题方法1: 1<<i
		for(int i = 0; i < 32;i++) {
		    if((N & (1<<i)) == (1<<i)) {
		    	total1++;
		    }
		}
		System.out.println("解题方法1: 1的数量: " + total1);
		
		//1的总数
		int total2 = 0;
		//解题方法2
		for(int i = 0;i < 32;i++) {
			if(((N >> i) & 1) == 1) {
				total2++;
			}
		}
		System.out.println("解题方法2: 1的数量: " + total2);
		
		//1的总数
		int total3 = 0;
		//解题方法3
		while(N != 0) {
			N = N & (N - 1);
			total3++;
		}
		System.out.println("解题方法2: 1的数量: " + total3);
	}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值