PAT乙级1019

PAT乙级10191019 数字黑洞(20 分)给定任一个各位数字不完全相同的4位正整数,如果我们先把4个数字按非递增排序,再按非递减排序,然后用第1个数字减第2个数字,将得到一个新的数字。一直重复这样做,我们很快会停在有“数字黑洞”之称的 6174,这个神奇的数字也叫Kaprekar常数。例如,我们从6767开始,将得到7766-6677=10899810-0189…

大家好,又见面了,我是你们的朋友全栈君。

1019 数字黑洞(20 分)

给定任一个各位数字不完全相同的 4 位正整数,如果我们先把 4 个数字按非递增排序,再按非递减排序,然后用第 1 个数字减第 2 个数字,将得到一个新的数字。一直重复这样做,我们很快会停在有“数字黑洞”之称的 6174,这个神奇的数字也叫 Kaprekar 常数。

例如,我们从6767开始,将得到

7766 - 6677 = 1089
9810 - 0189 = 9621
9621 - 1269 = 8352
8532 - 2358 = 6174
7641 - 1467 = 6174
... ...

现给定任意 4 位正整数,请编写程序演示到达黑洞的过程。

输入格式:

输入给出一个 (0,10​4​​) 区间内的正整数 N。

输出格式:

如果 N 的 4 位数字全相等,则在一行内输出 N - N = 0000;否则将计算的每一步在一行内输出,直到 6174 作为差出现,输出格式见样例。注意每个数字按 4 位数格式输出。

输入样例 1:

6767

输出样例 1:

7766 - 6677 = 1089
9810 - 0189 = 9621
9621 - 1269 = 8352
8532 - 2358 = 6174

输入样例 2:

2222

输出样例 2:

2222 - 2222 = 0000
#include<iostream>
#include<algorithm>
#include<cstdio>
using namespace std;
int m,n;
void mix(int x)
{
	int b[4];
	b[0]=x/1000;
	b[1]=x/100%10;
	b[2]=x/10%10;
	b[3]=x%10;
	sort(b,b+4);
	m=b[3]*1000+b[2]*100+b[1]*10+b[0];
	n=b[0]*1000+b[1]*100+b[2]*10+b[3];
}

int main()
{
	int a;
	cin>>a;
	int c=0;
	if ((a / 1000 == a / 100 % 10) && (a / 1000 == a / 10 % 10) && (a / 1000 == a % 10))
	{
		printf("%04d - %04d = 0000\n", a, a);
		return 0;
	}
	while(c!=6174)
	{
		mix(a);
		c=m-n;
		printf("%04d - %04d = %04d\n",m, n, c);
		//cout<<max1<<" "<<"-"<<" "<<min1<<" "<<"="<<c<<endl;
		a=c;
	}
	return 0;
}

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/138694.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • MySQL数据库:SQL优化与索引优化

    MySQL数据库:SQL优化与索引优化

    2021年4月9日
    151
  • pstack脚本_pstack

    pstack脚本_pstack脚本写入shell文件pstack,直接执行这个脚本pstackpid#!/bin/shiftest$#-ne1;thenecho”Usage:`basename$0.sh`<process-id>”1>&2exit1fiiftest!-r/proc/$1;thenecho”Process$1notfound.”1>&2exit1fi#GDBdoe…

    2022年9月14日
    2
  • delphi android 音乐播放器,Mcool音乐播放器

    delphi android 音乐播放器,Mcool音乐播放器Mcool音乐播放器APP是一款非常不错的手机音乐播放软件,用户可以使用该软件在线免费听大量好音乐,音质比较好,使用界面简洁明了,喜欢听音乐的朋友可以来西西下载Mcool音乐播放器APP使用!软件简介Windows受欢迎的Mcool音乐播放器,在很多用户要求下,终于推出安卓版本。只在一个月内,就很快从Windows版本复刻到安卓版本,这只有强大的Delphi能够做到。定位为“最简单的…

    2022年6月26日
    37
  • resnet50代码详解_一张图看懂系列

    resnet50代码详解_一张图看懂系列直接上流程图,算法很清晰。仅包括卷积层和全连接层,不包括池化层,正好50层。相比于ResNet_50,ResNet_101就是在上图第3个大虚线框多了17个bottleneck,17*3+50=101,说白了就是将下图复制17个加入上图的第3个大虚线框内:画图不易,转载请注明出处!…

    2022年10月6日
    4
  • pycharm2019.3.3激活成功教程_pycharm界面

    pycharm2019.3.3激活成功教程_pycharm界面PyCharm是由著名的JetBrains公司所打造的一款功能强大的PythonIDE,它具有一般IDE都具备的功能,并且使用起来非常方便好用。最近需求PyCharm激活码的网友非常多,小编就在这里给大家分享一下PyCharm2019最新可用的激活注册码。激活Pycharm专业版的方法有很多,小编在这里主要给大家分享最有效的两种,一种是使用最新可用的注册激活码,一种是使用激活成功教程补丁的方法,这种方法…

    2022年8月27日
    3
  • C#设计模式系列:命令模式(Command)

    C#设计模式系列:命令模式(Command)

    2021年8月29日
    93

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号