解题思路:主要是字符串和整数,数组和字符串,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 人评分
简单的a+b (C语言代码)浏览:827 |
拆分位数 (C语言代码)浏览:1361 |
WU-C语言程序设计教程(第三版)课后习题11.12 (C++代码)(想学链表的小伙伴可以看看)浏览:964 |
多输入输出练习2 (C语言代码)浏览:1711 |
简单的a+b (C语言代码)浏览:672 |
C语言程序设计教程(第三版)课后习题3.7 (C语言代码)浏览:415 |
WU-蛇行矩阵 (C++代码)浏览:659 |
矩形面积交 (C语言代码)浏览:1880 |
回文数字 (C++代码)浏览:913 |
WU-C语言程序设计教程(第三版)课后习题5.5 (C语言代码)浏览:862 |