美文网首页
* 编写函数计算任意位数的黑洞数。黑洞数是指这样的整数:由这个数

* 编写函数计算任意位数的黑洞数。黑洞数是指这样的整数:由这个数

作者: Ktry | 来源:发表于2020-10-08 13:53 被阅读0次
         * 编写函数计算任意位数的黑洞数。黑洞数是指这样的整数:由这个数字每位上的数
         * 字组成的最大数减去每位数字组成的最小数仍然得到这个数自身。例如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);
                }
            }
    
    

    相关文章

      网友评论

          本文标题:* 编写函数计算任意位数的黑洞数。黑洞数是指这样的整数:由这个数

          本文链接:https://www.haomeiwen.com/subject/ulxhpktx.html