13

I have do detect the amount of digits on a number. For example, 329586 has 6 digits.

What I done, is simply parsing the number to string, and getting the string length, like:

number.toString().length()

But, is there a fastest way to count digits on a number? I have to use this method several times, so I think using toString() can impact performance.

Thanks.

LOL
  • 13
  • 4
JoaaoVerona
  • 2,163
  • 3
  • 16
  • 29

3 Answers3

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

For example:

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

OUTPUT:

6
Eng.Fouad
  • 111,301
  • 67
  • 311
  • 403
10

how about this homebrewed solution:

int noOfDigit = 1;
while((n=n/10) != 0) ++noOfDigit;
TravellingGeek
  • 1,531
  • 11
  • 16
0

Try this :

Working Example

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);
    }
}
Zelldon
  • 5,238
  • 3
  • 32
  • 42