我确实检测到数字上的位数。例如,329586
有6
数字。
我所做的只是将数字解析为字符串,并获取字符串长度,例如:
number.toString().length()
但是,有没有一种最快的方法来计算数字的位数?我必须多次使用这种方法,所以我认为使用toString()
会影响性能。
谢谢。
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
这个自制的解决方案怎么样:
int noOfDigit = 1;
while((n=n/10) != 0) ++noOfDigit;
试试这个 :
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);
}
}