算法小可爱


私信TA

用户名:huanglizhen

访问量:483

签 名:

等  级
排  名 10309
经  验 1097
参赛次数 4
文章发表 5
年  龄 0
在职情况 学生
学  校 广东药科大学
专  业

  自我简介:

解题思路:主要是字符串和整数,数组和字符串,String和StringBuffer类型之间的转换,搞清楚就很简单了,逻辑上转得有点复杂,需要耐心去体体验

注意事项:

参考代码:

package Test;

import java.util.Scanner;

public class MainDemo {
   public static void main(String[] args) {
       Scanner sc = new Scanner(System.in);
       int n=sc.nextInt();
       int count=0;
       while(n!=6174){
           int[] a=run(n);//变成最大值数组
           //组合最大值
           int b=0;
           for(int i=0;i<a.length;i++){
               b=b*10+a[i];
           }
           //System.out.println(b);
           //组合最小值
           String ss=Integer.toString(b);
           StringBuffer s=new StringBuffer(ss);
           int c=Integer.parseInt(s.reverse().toString());
           //System.out.println(c);
           //两数相减
           n=b-c;
           count++;
       }
       System.out.println(count);
   }
   public static  int[] run(int n){//将整数进行分解和排序
       int[] t=new int[4];
       t[0]=n%10;
       t[1]=n/10%10;
       t[2]=n/100%10;
       t[3]=n/1000;
       for(int i=0;i<4;i++){
           for(int j=1;j<4-i;j++){
               if(t[j-1]<t[j]){
                   int temp=t[j-1];
                   t[j-1]=t[j];
                   t[j]=temp;
               }
           }
       }
       return t;

   }
}



 

0.0分

0 人评分

  评论区

  • «
  • »