将十进制转为二进制

旧城冷巷雨未停 提交于 2019-11-29 00:48:30
public static void integerToBinary(Integer number){
        //使用num%2得到商和余数
        //使用上一步的商%2
        //直到商为o, 将这些余数到倒过来就是二进制

        int remainder = 0; //余数
        int quotient = 0; //商

        StringBuilder s = new StringBuilder();

        while(number > 0){
        remainder = number % 2;
        quotient = number / 2;
        s.append(Integer.toString(remainder));
        number = quotient;
        }

        System.out.println(s.reverse().toString()); //将字符串倒过来
    }
public static void integerToBinaryUseStack(Integer number){
        //使用num%2得到商和余数
        //使用上一步的商%2
        //直到商为o

        int remainder = 0; //余数
        int quotient = 0; //商

        Stack<Integer> stack = new Stack<Integer>();

        while(number > 0){
            remainder = number % 2;
            quotient = number / 2;
            stack.push(remainder);
            number = quotient;
        }

        while (!stack.empty()){
            System.out.print(stack.pop()); //哈哈, 使用队列后进先出的特点
        }
    }

测试代码

public static void main(String[] args) {

        //6的2进制数为110
//        System.out.println(6%2); //3 0
//        System.out.println(3/2); //1 1
//        System.out.println(1%2); //0 1

        integerToBinary(6); //110
        integerToBinaryUseStack(6);  //110
    }
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!