GSEP 2级T2真题 [202309]数字黑洞

题目描述

给定一个三位数,要求各位不能相同。例如 352, 是符合要求的,112 是不符合要求的。将这个三位数的三个数字重新排列,得到的最大的数,减去得到的最小的数,形成一个新的三位数。对这个新的三位数可以重复上述过程。神奇的是,最终一定会得到 495 !

试试看,重新排列 352 ,得到的最大数为 532,最小数为 235,它们的差是 297 ;变换 297,得到 972 - 279 = 693;变换 693,963 - 369 = 594;变换 594,954 - 459 = 495 。因此,352 经过 4 次变换得到了 495 。

现在,输入的三位数,你能通过编程得出,这个三位数经过多少次变换能够得到 495 吗?

输入

输入一行,包含一个符合要求的三位数 N 。

输出

输出一行,包含一个整数 C,表示经过 C 次变换得到 495。

样例输入 
352
样例输出 
4

带注释版AC代码:

#include<bits/stdc++.h>//万能头文件
int maxof3(int a, int b, int c)//求最大值
{
	int t;
	if (a < b)
	{
		t = a;
		a = b;
		b = t;
	}
	if (a < c)
	{
		t = a;
		a = c;
		c = t;
	}
	if (b < c)
	{
		t = b;
		b = c;
		c = t;
	}//a>b>c
	return (a * 100 + b * 10 + c);
}
int minof3(int a, int b, int c)//求最小值
{
	int t;
	if (a < b)
	{
		t = a;
		a = b;
		b = t;
	}
	if (a < c)
	{
		t = a;
		a = c;
		c = t;
	}
	if (b < c)
	{
		t = b;
		b = c;
		c = t;
	}//a>b>c
	return (100 * c + 10 * b + a);
}
int main()
{
	int num, cnt = 0;
	int a1, b1, c1;
	int max, min;
	scanf("%d", &num);
	while (num != 495)
	{
		c1 = num % 10;
		b1 = num / 10 % 10;
		a1 = num / 100;
		max = maxof3(a1, b1, c1);
		min = minof3(a1, b1, c1);
		num = max - min;
		cnt++;
	}
	printf("%d", cnt);
	return 0;
}

不带注释版AC代码:

#include<bits/stdc++.h>
int maxof3(int a, int b, int c)
{
	int t;
	if (a < b)
	{
		t = a;
		a = b;
		b = t;
	}
	if (a < c)
	{
		t = a;
		a = c;
		c = t;
	}
	if (b < c)
	{
		t = b;
		b = c;
		c = t;
	}//a>b>c
	return (a * 100 + b * 10 + c);
}
int minof3(int a, int b, int c)
{
	int t;
	if (a < b)
	{
		t = a;
		a = b;
		b = t;
	}
	if (a < c)
	{
		t = a;
		a = c;
		c = t;
	}
	if (b < c)
	{
		t = b;
		b = c;
		c = t;
	}
	return (100 * c + 10 * b + a);
}
int main()
{
	int num, cnt = 0;
	int a1, b1, c1;
	int max, min;
	scanf("%d", &num);
	while (num != 495)
	{
		c1 = num % 10;
		b1 = num / 10 % 10;
		a1 = num / 100;
		max = maxof3(a1, b1, c1);
		min = minof3(a1, b1, c1);
		num = max - min;
		cnt++;
	}
	printf("%d", cnt);
	return 0;
}

 

 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值