给定任一个各位数字不完全相同的4位正整数,如果我们先把4个数字按非递增排序,再按非递减排序,然后用第1个数字减第2个数字,将得到 一个新的数字。一直重复这样做,我们很快会停在有“数字黑洞”之称的6174,这个神奇的数字也叫Kaprekar常数。 例如,我们从6767开始,将得到 7766 - 6677 = 1089 9810 - 0189 = 9621 9621 - 1269 = 8352 8532 - 2358 = 6174 7641 - 1467 = 6174 ... ... 现给定任意4位正整数,请编写程序演示到达黑洞的过程。
public class Main{
public static void main(String[] args){
Scanner sc = new Scanner(System.in);
String s = sc.nextLine();
int le = 4-s.length();
for(int i = 0;i<le;i++){
s = "0"+s;
}
result(s);
}
public static void result(String s){
char[] nums = s.toCharArray();
int temp = 0;
char tempChar = '0';
String maxStr = "";
String minStr = "";
for(int i = 0;i<nums.length;i++){
temp = i;
for(int j = i+1;j<nums.length;j++){
if(nums[temp]>=nums[j]){
temp = j;
}
}
if(temp != i){
tempChar = nums[i];
nums[i] = nums[temp];
nums[temp] = tempChar;
}
minStr+=nums[i];
}
maxStr = new StringBuffer(minStr).reverse().toString();
int num = Integer.parseInt(maxStr)-Integer.parseInt(minStr);
String str = num+"";
int lee = 4-str.length();
for(int i = 0;i<lee;i++){
str = "0"+str;
}
System.out.println(maxStr+" - "+minStr+" = "+str);
if(num!=6174&&num!=0){
String numStr = num+"";
int le = 4-numStr.length();
for(int i = 0;i<le;i++){
numStr = "0"+numStr;
}
result(numStr);
}
}
}