6174问题
时间限制:
1000 ms | 内存限制:
65535 KB
难度:
2
-
描述
-
假设你有一个各位数字互不相同的四位数,把所有的数字从大到小排序后得到a,从小到大后得到b,然后用a-b替换原来这个数,并且继续操作。例如,从1234出发,依次可以得到4321-1234=3087、8730-378=8352、8532-2358=6174,又回到了它自己!现在要你写一个程序来判断一个四位数经过多少次这样的操作能出现循环,并且求出操作的次数
比如输入1234执行顺序是1234->3087->8352->6174->6174,输出是4
-
输入
-
第一行输入n,代表有n组测试数据。
接下来n行每行都写一个各位数字互不相同的四位数
输出
- 经过多少次上面描述的操作才能出现循环 样例输入
-
1 1234
样例输出
-
4
-
第一行输入n,代表有n组测试数据。
程序如下:
#include<stdio.h>
#include<string.h>
int sort_max(int x){ //将数字由大到小排序输出
int i,j,t,max;
int a[4];
for(i = 3; i >= 0; i--){ //将数字拆分,存到数组里
a[i] = x%10;
x = x/10;
}
for(i = 0; i < 4; i++){
for(j = i+1; j < 4; j++){
if(a[i] < a[j]){
t = a[i];
a[i] = a[j];
a[j] = t;
}
}
}
max = a[0]*1000 + a[1]*100 + a[2]*10 + a[3];
return max;
}
int sort_min(int x){ //将数字由小到大排序输出
int i,j,t,min;
int a[4];
for(i = 3; i >= 0; i--){ //将数字拆分,存到数组里
a[i] = x%10;
x = x/10;
}
for(i = 0; i < 4; i++){
for(j = i+1; j < 4; j++){
if(a[i] > a[j]){
t = a[i];
a[i] = a[j];
a[j] = t;
}
}
}
min = a[0]*1000 + a[1]*100 + a[2]*10 + a[3];
return min;
}
int main(){
int n,x,i;
int count;
int max,min,dis;
scanf("%d",&n);
while(n--){
scanf("%d",&x);
count = 0;
while(true){
count++;
max = sort_max(x);
min = sort_min(x);
x = max - min;
if(x == dis){
break;
}
dis = x; //用dis来记录上一次的差值
}
printf("%d\n",count);
}
return 0;
}
运行结果如下: