Java实现查找输入整数二进制中1的个数
2017-06-02 09:57
295 查看
题目描述
请实现如下接口public static int findNumberOf1(intnum)
{
/* 请实现 */
return 0;
}譬如:输入5 ,5的二进制为101,输出2
涉及知识点:
输入描述:
输入一个整数
输出描述:
计算整数二进制中1的个数
输入例子:
5
输出例子:
2
这个题我也是醉了。我觉得很简单啊,直接toBinaryString,多么easy。
我的代码在eclipse下是正确的,但是在在线编译ide上出了不结果??OMG。。。。
import java.util.*;
public class Main {
public static void main(String args[]){
Scanner sc=new Scanner(System.in);
int num=sc.nextInt();
System.out.println(findNumberof1(num));
}
public static int findNumberof1(int num){
String s=Integer.toBinaryString(num);
int count=0;
for(int i=0;i<s.length();i++){
if(s.charAt(i)=='1'){
count++;
}
}
return count;
}
}
好嘛~!!
非要硬写2进制是不??来来来,写嘛
public static int findNumberof1(int num){
int count=0;
boolean flag=true;
while(flag){
if(num%2==1){
count++;
}
num=num/2;
if(num==0){
flag=false;
}
}
return count;}
然后我遇到了一个最无法解决的bug,
怎么调试都不对!!在线编译跟我说程序没有输出!!
怎么可能!怎么可能!!!
最后实在不行了,我看了一下讨论区的代码:
import java.util.Scanner;
public class Main {
/**
* @param args
*/
public static void main(String[] args) {
// TODO Auto-generated method stub
Scanner scan = new Scanner(System.in);
while(scan.hasNext()){
int n = scan.nextInt();
int count = 0;
String str = Integer.toBinaryString(n);
char[] cha = str.toCharArray();
for(char c :cha){
if(c=='1'){
count++;
}
}
System.out.println(count);
}
}
}
呵呵,
不是,你要多次输入,你倒是说明白啊....
又不是不会,但是你得说清楚了不是?!
相关文章推荐
- 我想得到文本框中输入的三位的整数,用java的正则表达式怎么实现啊?
- 【华为OJ】查找输入整数二进制中1的个数
- 华为oj 查找输入整数二进制中1的个数
- java-01-实现多行输入 并且以指定end 字符(串) 结束 并且查找指定的单个字符
- 华为OJ 初级:查找输入整数二进制中1的个数
- 第十二周项目 输入一个整数n,要求用递归函数实现对应的二进制形式。
- 在java中实现输入两个正整数m和n,求最大的公约数和最小公倍数
- *查找输入整数二进制中1的个数
- 华为oj 查找输入整数二进制中1的个数
- Java实现:n个正整数,将它们连接成一排,组成一个最大的多位整数。(输入:n(n个整数),依次输入n个整数)
- 查找输入整数二进制中1的个数
- Java实现输入一个整数将该整数之前的所有素数输出出来
- 用 java 编写程序实现输入4个整数输出4个整数的和
- 剑指offer中,求输入整数的二进制形式中1的个数(Java代码)
- HWOJ 查找输入整数二进制中1的个数
- JAVA实现输入一个整数,输出该数二进制表示中1的个数(《剑指offer》)
- 中文字符串转为long型整数。(输入保证在long的范围内)java实现
- 输入三个整数,并从小到大的顺序输出(java实现)
- java 用递归实现:输入一个整数,用字符串逆序输出,例如输入123,输出321 ,不使用全局变量
- 华为OJ——查找输入整数二进制中1的个数