题解 | #求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);
        //接收输入的正整数
        int inputNum = in.nextInt();
        //计数器,用来计数正整数转换为2进制后1的个数
        int cnt = 0;
        //正整数转换为二进制的过程
        //正整数除以2的商为0时结束循环,说明二进制转换完成
        while(inputNum != 0){
            //拿到除2的余数
            int modNum = inputNum % 2;
            //余数为1时计数器加1
            if(modNum == 1) cnt++;
            //将商赋值给正整数
            inputNum /= 2;
        }
        System.out.println(cnt);
    }
}

全部评论

相关推荐

05-04 17:20
武汉大学
已注销:技术栈删了,让ai把你的项目丰富化,干的活太少了,像是写了个demo,起码一个项目四点重要内容,内容用技术栈描述,取得了什么进展,简历大部分都留给项目,其他的压缩
如何写一份好简历
点赞 评论 收藏
分享
04-14 12:52
已编辑
门头沟学院 C++
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务