亲宝软件园·资讯

展开

求整数的位数

Mingyueyixi 人气:0

求整数的位数

一般有几种方法,其一是转成字符串求,缺点是字符串耗时间长;另一种是用Math.log10();用log函数;还有一种用循环除以10的方式求出;最后一种,直接判断<10,<100,<1000,<10000……或许效率挺高吧,因为不需要计算。

其一

private static int getNumLenght(long num){
        num = num>0?num:-num;       
        return String.valueOf(num).length();
    }

其二

private static int getNumLenght(long num){
        num = num>0?num:-num;       
        if (num==0) {
            return 1;
        }
        return (int) Math.log10(num)+1;
    }

其三

private static int getNumLenght(long num){
        if (num==0) {
            return 1;
        }
        int lenght = 0;
        for (long temp = num ; temp != 0; temp/=10){
            lenght++;
        }
        return lenght;
    }

最后一种老长老长,不写了。

java整数位数判断

public class Test {    
final static int[] sizeTable = { 9, 99, 999, 9999, 99999, 999999, 9999999,    
99999999, 999999999, Integer.MAX_VALUE };    
public static void main(String[] args) {    
        System.out.println(sizeOfInt(1234));    
    }    
    static int sizeOfInt(int x) {    
      for (int i = 0;; i++)    
        if (x <= sizeTable[i])    
        return i + 1;    
        } 
}  

以上为个人经验,希望能给大家一个参考,也希望大家多多支持。

加载全部内容

相关教程
猜你喜欢
用户评论