【C/C++】循环结构-数字黑洞

给定一个三位数,要求各位不能相同。例如,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次变换得到 。

示例:

输入:

352

输出:

4

#include<stdio.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;
}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
数据结构课程设计c/c++版--美团餐馆预定信息的管理与分析。 本课程设计旨在设计一个C/C++程序,用于管理和分析美团餐馆的预定信息。通过合理的数据结构设计和算法编程,实现对餐馆的预定信息进行管理和分析,以提高用户的预定体验和餐馆的效益。 首先,需要设计合适的数据结构来存储餐馆的预定信息。可以利用链表、数组、队列等数据结构来存储餐馆的基本信息(如名称、地址、电话等)和预定信息(如预定日期、预定时间、预定人数等)。通过数据结构的合理选择和设计,能够提高程序的运行效率和数据的访问速度。 其次,需要设计相应的功能模块来管理餐馆的预定信息。包括添加餐馆信息、查询餐馆信息、预定餐馆、取消预定等功能。通过各个功能模块之间的有机组合和调用,能够实现对预定信息的全面管理和操作。 最后,需要设计一些算法来进行预定信息的分析。可以通过统计预定信息的频次、根据用户的偏好推荐适合的餐馆等方法,对预定信息进行分析和挖掘。这样可以从大量的数据中挖掘出有价值的信息,进一步提高餐馆的运营策略和用户的预定体验。 通过本课程设计,不仅能够提高学生对数据结构的理解和应用能力,还能够锻炼学生的问题分析和解决能力。同时,也能够为美团等餐饮平台提供有价值的参考和借鉴。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值