6174質問

1347 ワード

6174推測、1955年、カプエカ(D.R.Kaprekar)は4桁の変換を研究した:4桁のk 0を与えて、その4つの数字で大きいから小さいまで再び1つの4桁のmに並べ替えて、更にその逆序数rev(m)を減らして、数k 1=m-rev(m)を得て、しかしその後、k 1に対して上述の変換を繰り返して、k 2を得た.このようにして、カプエカは、k 0がどんなに大きな4桁であっても、4つの数字が同じでない限り、最大7回以上上記の変換を行うと、4桁6174が現れることを発見した.
import java.io.BufferedInputStream;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Scanner;


public class B23
{
	public static int getInt(int a){
		int n=1;
		int temp=a/10;
		while(temp!=0){
			temp=temp/10;
			n++;
		}
		int[] num=new int[n];
		
		for(int i=0;i<n;i++){
			num[i]=(a/(int)Math.pow(10, i))%10;
			
		}
		Arrays.sort(num);
		int n2=0;
		int n1=0;
		int[] num2=new int[n];
		for(int i=0;i<n;i++){
			num2[i]=num[n-1-i];
			n2*=10;
			n2+=num2[i];
			n1*=10;
			n1+=num[i];
		}
		return n2-n1;
		
	}
	
	
	public static void main(String[] args)
	{  
	    ArrayList<Integer> l=new ArrayList<Integer>();
	    int m=0;
	    Scanner cin=new Scanner(new BufferedInputStream(System.in));
	    if(cin.hasNext()){
	    	m=cin.nextInt();
	    }
	    l.add(m);
	   int temp=m;
	   out:for(;;){
	    	 temp=getInt(temp);
	    	
	    	 System.out.printf(">>%d   ",temp);
	    	 for(int i=0;i<l.size();i++){
	    		 if(l.get(i)==temp){
	    			 break out;
	    		 }
	    	 }
	    	 l.add(temp); 
	    }
	    
	}
}