A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© zhoubinjian 金牌黑马   /  2016-3-21 00:47  /  390 人查看  /  0 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文


/*查表法,通过定义一个临时数组来储存数据。然后将取出来的元素存到一个临时的数组中,再输出有效位*/
class Lianxi
{
        public static void main(String[] args)
        {
                toer(60);
        }
       
        public static void toer(int num)//十进制转二进制
                {
                        getnum(num,1,1);
       
                }
        public static void toba(int num)//十进制转八进制
                {
                        getnum(num,7,3);
       
                }
        public static void toshiliu(int num)//十进制转十六进制
                {
                        getnum(num,15,4);
       
                }
       
        public static void getnum(int num,int a,int b)
        {
                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)//num不断右移,有效位取出来时,后面的都是0000,跳出循环。
                {
                        int temp=num&a;
                        arr[--pos]=chs[temp];//&15后的值存到临时数组,此方式目的是存到该数组中的元素是正常顺序。
                        num=num>>>b;
                }

                for(int x=pos;x<arr.length;x++)//打印有效位,0000不打印
                {
                        System.out.print(arr[x]+",");
               
                }

       
        }
}

0 个回复

您需要登录后才可以回帖 登录 | 加入黑马