13

我确实检测到数字上的位数。例如,3295866数字。

我所做的只是将数字解析为字符串,并获取字符串长度,例如:

number.toString().length()

但是,有没有一种最快的方法来计算数字的位数?我必须多次使用这种方法,所以我认为使用toString()会影响性能。

谢谢。

4

3 回答 3

41
Math.floor(Math.log10(number) + 1)
// or just (int) Math.log10(number) + 1

例如:

int number = 123456;
int length = (int) Math.log10(number) + 1;
System.out.println(length);

输出:

6
于 2013-03-23T14:24:29.393 回答
10

这个自制的解决方案怎么样:

int noOfDigit = 1;
while((n=n/10) != 0) ++noOfDigit;
于 2013-03-23T14:29:18.917 回答
0

试试这个 :

工作示例

public class Main {
    public static void main(String[] args) {
        long num = -23;
        int digits = 0;
        if (num < 0) 
            num *= (-1);
        if (num < 10 && num >= 0)
            digits = 1;
        else {
            while(num > 0) {
                num /= 10;
                digits++;
            }
        }
        System.out.println("Digits: " +digits);
    }
}
于 2013-03-23T14:31:56.603 回答