黑马程序员技术交流社区

标题: 练习:进制相互转换。 [打印本页]

作者: 逸风    时间: 2015-4-11 15:07
标题: 练习:进制相互转换。
class ArrayTest
{
        public static void main(String[] args)
        {
                //toBin(-6);
                //toBa(-20);
                toHex(-60);
        }

        /*
        十进制-->二进制
        */
        public static void toBin(int num)
        {
                trans(num,1,1);
        }
       
        /*
        十进制-->八进制
        */
        public static void toBa(int num)
        {
                trans(num,7,3);
        }
       
        /*
        十进制-->十六进制
        */
        public static void toHex(int num)
        {
                trans(num,15,4);
        }
       
        public static void trans(int num,int base,int offset)
        {
                if(num==0)
                {
                        System.out.println(0);
                        return;
                }
                char[] chs = {'0','1','2','3',
                                          '4','5','6','7',
                                          '8','9','A','B',
                                          'C','D','E','F',};
                char[] arr = new char[32];
                int pos = arr.length;
                while(num!=0)
                {
                        int temp = num & base;
                        arr[--pos] = chs[temp];
                        num = num >>> offset;
                }
                for(int x=pos; x<arr.length; x++)
                {
                        System.out.print(arr[x]);
                }       
        }
}

作者: sisel    时间: 2015-4-11 22:13
base原来是mask 不错不错! 不过mask可以通过offset来计算出来,不需要传
作者: 帆风顺    时间: 2015-4-12 00:16
用到了查表法!




欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2