* 编写函数计算任意位数的黑洞数。黑洞数是指这样的整数:由这个数字每位上的数 * 字组成的最大数减去每位数字组成的最小数仍然得到这个数自身。例如3位黑洞数 *...

     * 编写函数计算任意位数的黑洞数。黑洞数是指这样的整数:由这个数字每位上的数
     * 字组成的最大数减去每位数字组成的最小数仍然得到这个数自身。例如3位黑洞数
     * 是495,因为954-459=495,4位数字是6174,因为7641- 1467-6174。。
/**
         * 编写函数计算任意位数的黑洞数。黑洞数是指这样的整数:由这个数字每位上的数
         * 字组成的最大数减去每位数字组成的最小数仍然得到这个数自身。例如3位黑洞数
         * 是495,因为954-459=495,4位数字是6174,因为7641- 1467-6174。。
         */

        int length = 4; //需要求几位数的黑洞数
        for(int data = (int)Math.pow(10, length - 1);data < (int)Math.pow(10, length);data++) { //从最小数循环到最大数
            String[] split = (data + "").split("");  //将这个数转换为String[]类型数组
            int[] max = new int[split.length];               //定义空int[]数组,存放最大排列结果
            int[] min = new int[split.length];               //定义空int[]数组,存放最小排列结果
            for (int i = 0; i < split.length; i++) {         //遍历String[]类型数组存到int[]
                min[i] = Integer.parseInt(String.valueOf(split[i]));
            }
            Arrays.sort(min);                                 //升序排序(即最小排列)
            for (int m = min.length - 1; m >= 0; m--) {
                max[min.length - 1 - m] = min[m];             //倒序排序(即最大排列)
            }
            String maxStr = "";
            for (int i = 0; i < max.length; i++) {
                maxStr = maxStr + max[i];                      //int[]转化int
            }
            String minStr = "";
            for (int i = 0; i < min.length; i++) {
                minStr = minStr + min[i];                      //int[]转化int
            }
            if (Integer.parseInt(maxStr) - Integer.parseInt(minStr) == data) {  //判断黑洞数
                System.out.println(length+"位数>>>"+data);
            }
        }

你可能感兴趣的:(* 编写函数计算任意位数的黑洞数。黑洞数是指这样的整数:由这个数字每位上的数 * 字组成的最大数减去每位数字组成的最小数仍然得到这个数自身。例如3位黑洞数 *...)