P 1019 数字黑洞
转跳点:
给定任一个各位数字不完全相同的 4 位正整数,如果我们先把 4 个数字按非递增排序,再按非递减排序,然后用第 1 个数字减第 2 个数字,将得到一个新的数字。一直重复这样做,我们很快会停在有“数字黑洞”之称的 6174,这个神奇的数字也叫 Kaprekar 常数。
例如,我们从6767开始,将得到
7766 - 6677 = 1089
9810 - 0189 = 9621
9621 - 1269 = 8352
8532 - 2358 = 6174
7641 - 1467 = 6174
... ...
现给定任意 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
这道题我取了一下巧,用来sscanf,因为实在是不想写个各个位相加的了,太麻烦了。这道题吧,还是那句话没什么难点。就是有些小坑
1.结束程序的情况有两个,while (n != 6174 && n != 0)
2.注意一下输入是6174的情况。如果你写的不是先减后判断的退出条件的话那就出现直接推出的情况,但理论上应该输出7641 - 1467 = 6174,所以要么用do……while,
要么换一下逻辑顺序,先减再判断
3.注意一下1000 这种东西输出的时候得是 1000 - 0001 = 999
我踩到的坑就这些,个人感觉是没有其他的了。如果不用sscanf将数组里的数字字符写入变量里那取各个位的时候就要注意记得不足四位要加上0。接着就是贴代码的环节了。
哦,对了,要用到排序,上一篇博客铁锅qsort使用方法,这里就不贴了,记得写两个比较函数,其实自己想练练手写个排序也行。
C:
1 #include <stdio.h>
2 #include <stdlib.h>
3
4 int cmp1(const void *a, const void *b);
5 int cmp2(const void *a, const void *b);
6 void to_array(int a, char b[]);
7
8 int main()
9 {
10 char num[5];
11 int n;
12 scanf("%d", &n);
13 do
14 {
15 to_array(n, num);
16 int max, min;
17
18 qsort(num, 4, sizeof(char), cmp1);
19 sscanf(num, "%d", &min);
20 qsort(num, 4, sizeof(char), cmp2);
21 sscanf(num, "%d", &max);
22 printf("%04d - %04d = %04d\n", max, min, max - min);
23 n = max - min;
24 } while (n != 6174 && n != 0);
25
26
27 return 0;
28 }
29
30 int cmp1(const void *a, const void *b)
31 {
32 return *((char *)a) > *((char *)b) ? 1 : -1;
33 }
34
35 int cmp2(const void *a, const void *b)
36 {
37 return *((char *)a) > *((char *)b) ? -1 : 1;
38 }
39
40 void to_array(int a, char b[])
41 {
42 for (int i = 0; i < 4; i++)
43 {
44 b[i] = a % 10 + '0';
45 a /= 10;
46 }
47 }
C++
1 #include <stdio.h>
2 #include <algorithm>
3 using namespace std;
4
5 bool cmp(int a, int b);
6 void to_array(int a, char b[]);
7
8 int main()
9 {
10 char num[5];
11 int n;
12 scanf("%d", &n);
13 do
14 {
15 to_array(n, num);
16 int max, min;
17
18 sort(num, num + 4);
19 sscanf(num, "%d", &min);
20 sort(num, num + 4, cmp);
21 sscanf(num, "%d", &max);
22
23 printf("%04d - %04d = %04d\n", max, min, max - min);
24 n = max - min;
25 } while (n != 6174 && n != 0);
26
27 return 0;
28 }
29
30 bool cmp(int a, int b)
31 {
32 return a > b;
33 }
34
35 void to_array(int a, char b[])
36 {
37 for (int i = 0; i < 4; i++)
38 {
39 b[i] = a % 10 + '0';
40 a /= 10;
41 }
42 }
其实也没怎么用c++的东西,因为sscanf的关系不能用vector,主要是懒得再开个空间用于memcpy拷贝
PTA不易,诸君共勉!
P 1019 数字黑洞的更多相关文章
- PAT乙级 1019. 数字黑洞 (20)
1019. 数字黑洞 (20) 时间限制 100 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 给定任一个各位数字不完全相同的4位 ...
- PAT-乙级-1019. 数字黑洞 (20)
1019. 数字黑洞 (20) 时间限制 100 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 给定任一个各位数字不完全相同的4位 ...
- 牛客网 PAT 算法历年真题 1009 : 1019. 数字黑洞 (20)
1019. 数字黑洞 (20) 时间限制 1000 ms 内存限制 32768 KB 代码长度限制 100 KB 判断程序 Standard (来自 小小) 题目描述 给定任一个各位数字不完全相同的4 ...
- PAT 乙级 1019 数字黑洞 (20) C++版
1019. 数字黑洞 (20) 时间限制 100 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 给定任一个各位数字不完全相同的4位 ...
- 【PAT】1019 数字黑洞 (20)(20 分)
1019 数字黑洞 (20)(20 分) 给定任一个各位数字不完全相同的4位正整数,如果我们先把4个数字按非递增排序,再按非递减排序,然后用第1个数字减第2个数字,将得到一个新的数字.一直重复这样做, ...
- PAT(B) 1019 数字黑洞(Java)
题目链接:1019 数字黑洞 (20 point(s)) 分析 输入正整数n后,将n转成int型数组nArr[4] 用Arrays.sort(int[] a)方法将数组nArr非递减排序 很显然,非递 ...
- PAT——1019. 数字黑洞
给定任一个各位数字不完全相同的4位正整数,如果我们先把4个数字按非递增排序,再按非递减排序,然后用第1个数字减第2个数字,将得到一个新的数字.一直重复这样做,我们很快会停在有“数字黑洞”之称的6174 ...
- PAT (Basic Level) Practise (中文)-1019. 数字黑洞 (20)
http://www.patest.cn/contests/pat-b-practise/1019 给定任一个各位数字不完全相同的4位正整数,如果我们先把4个数字按非递增排序,再按非递减排序,然后用第 ...
- PAT 1019. 数字黑洞 (20)
给定任一个各位数字不完全相同的4位正整数,如果我们先把4个数字按非递增排序,再按非递减排序,然后用第1个数字减第2个数字,将得到一个新的数字.一直重复这样做,我们很快会停在有"数字黑洞&qu ...
随机推荐
- 标准模板库中的优先队列(priority_queue)
//C++数据结构与算法(第4版) Adam Drozdek 著 徐丹 吴伟敏<<清华大学出版社>> #include<queue> priority_queu ...
- SpringCloud实战——(3)通过RESTful方式调用模块的方法
在项目中创建一个类,编写如下内容: package com.f*iservice.controller; import org.springframework.web.bind.annotation. ...
- Linux命令:history命令历史的管理及用法
bash可以保存的过去曾经执行过的命令.当某个用户登录到shell中,会读取该用户家目录中的~/.bash_history文件,并将历史命令列表保存到内存中.当用户退出当前shell时,会将内存中的历 ...
- 如何在cmd中连接数据库
数据库连接时遇到的问题 : https://www.cnblogs.com/xyzdw/archive/2011/08/11/2135227.htmlping +ip地址: 查看本机ip:ipconf ...
- 【高软作业4】:Tomcat 观察者模式解析 之 Lifecycle
一. 预备 如果你是Windows用户,使用Eclipse,并且想自行导入源码进行分析,你可能需要:Eclipse 导入 Tomcat 源码 如果你已遗忘 观察者模式,那么你可以通过该文章回顾:设计模 ...
- JSTL1.0和JSTL1.1的区别
这要从一个异常说起 According to TLD or attribute directive in tag file, attribute value does not accept any e ...
- NO21 Llinux的文件种类与扩展名--文件权限--软硬链接--Linux删除文件原理
Linux的文件种类与扩展名 一.文件种类:1.普通文件(regular file)第一个字符为[ - ]包括:①纯文本档(ASCII):这是Linux系统中最多的一种文件类型,称为纯文本档.是因为内 ...
- 阿里云安装mysql,初始化密码修改
阿里云服务器,centos7, rpm包安装MySQL,初始化了个奇葩密码 登陆不上, 修改配置文件/etc/my.cnf,在[mysqld]下面添加一行代码:skip-grant-tables se ...
- 安卓10GB内存旗舰手机的普及,能成为拯救DRAM厂商的救命稻草吗?
你对2019年手机即将展现出的全新变化,有哪些期待?是全新的处理器.更名副其实的全面屏,还是愈发强大的拍照功能,抑或折叠屏幕?但不管你有怎样的期待,手机厂商似乎总是"不解风情".常 ...
- Win7安装Oracle Instantclient ODBC驱动 后配置DSN时出错的解决办法 SQORAS32
安装过程简述 oracle官网下载了 instantclient-odbc-nt--.zip instantclient-basic-nt-.zip 我这是32位版的win7,按照需要下载对应的版本. ...