* 编写函数计算任意位数的黑洞数。黑洞数是指这样的整数:由这个数字每位上的数
* 字组成的最大数减去每位数字组成的最小数仍然得到这个数自身。例如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);
}
}