解题思路:主要是字符串和整数,数组和字符串,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 人评分
C语言程序设计教程(第三版)课后习题3.7 (C语言代码)浏览:571 |
模拟计算器 (C语言代码)浏览:896 |
C语言训练-素数问题 (C语言代码)浏览:1662 |
DNA (C语言描述,数据结构)浏览:864 |
C语言程序设计教程(第三版)课后习题8.8 (C语言代码)浏览:644 |
【矩阵】 (C++代码)浏览:951 |
简单的a+b (C语言代码)浏览:424 |
C语言程序设计教程(第三版)课后习题12.3 (C语言代码)浏览:548 |
C语言程序设计教程(第三版)课后习题7.4 (C语言代码)浏览:492 |
上车人数 (C语言代码)浏览:716 |