
PAT (Basic Level) Practice
guangjinzheng
这个作者很懒,什么都没留下…
展开
-
1002 写出这个数 (20point(s)) (PAT乙级Python3)
1002写出这个数(20point(s))读入一个正整数n,计算其各位数字之和,用汉语拼音写出和的每一位数字。输入格式:每个测试输入包含 1 个测试用例,即给出自然数n的值。这里保证n小于10100。输出格式:在一行内输出n的各位数字之和的每一位,拼音数字间有 1 空格,但一行中最后一个拼音数字后没有空格。输入样例:1234567890987...原创 2020-02-05 16:56:04 · 250 阅读 · 0 评论 -
1030 完美数列(PAT 乙级 中文 C/C++语言)
1030 完美数列 (25 point(s))给定一个正整数数列,和正整数 p,设这个数列中的最大值是 M,最小值是 m,如果 M≤mp,则称这个数列是完美数列。现在给定参数 p 和一些正整数,请你从中选择尽可能多的数构成一个完美数列。输入格式:输入第一行给出两个正整数 N 和 p,其中 N(≤105)是输入的正整数的个数,p(≤109)是给定的参数。第二行给出 N 个...原创 2019-01-24 18:06:38 · 292 阅读 · 0 评论 -
1025 反转链表(PAT 乙级 中文 C/C++语言)
1025 反转链表 (25 point(s))给定一个常数 K 以及一个单链表 L,请编写程序将 L 中每 K 个结点反转。例如:给定 L 为 1→2→3→4→5→6,K 为 3,则输出应该为 3→2→1→6→5→4;如果 K 为 4,则输出应该为 4→3→2→1→5→6,即最后不到 K 个元素不反转。输入格式:每个输入包含 1 个测试用例。每个测试用例第 1 行给出第 1 个结点的地...原创 2019-01-24 17:28:29 · 280 阅读 · 0 评论 -
1094 谷歌的招聘(PAT 乙级 中文 C/C++语言)
1094 谷歌的招聘 (20 point(s))2004 年 7 月,谷歌在硅谷的 101 号公路边竖立了一块巨大的广告牌(如下图)用于招聘。内容超级简单,就是一个以 .com 结尾的网址,而前面的网址是一个 10 位素数,这个素数是自然常数 e 中最早出现的 10 位连续数字。能找出这个素数的人,就可以通过访问谷歌的这个网站进入招聘流程的下一步。自然常数 e 是一个著名的超越数,前面...原创 2019-01-14 15:42:47 · 571 阅读 · 0 评论 -
1092 最好吃的月饼 (PAT 乙级 中文 C/C++语言)
1092 最好吃的月饼 (20 point(s))月饼是久负盛名的中国传统糕点之一,自唐朝以来,已经发展出几百品种。若想评比出一种“最好吃”的月饼,那势必在吃货界引发一场腥风血雨…… 在这里我们用数字说话,给出全国各地各种月饼的销量,要求你从中找出销量冠军,认定为最好吃的月饼。输入格式:输入首先给出两个正整数 N(≤1000)和 M(≤100),分别为月饼的种类数(于是默认月饼...原创 2019-01-14 14:52:51 · 387 阅读 · 0 评论 -
1091 N-自守数 (PAT 乙级 中文 C/C++语言)
1091 N-自守数 (15 point(s))如果某个数 K 的平方乘以 N 以后,结果的末尾几位数等于 K,那么就称这个数为“N-自守数”。例如 3×922=25392,而 25392 的末尾两位正好是 92,所以 92 是一个 3-自守数。本题就请你编写程序判断一个给定的数字是否关于某个 N 是 N-自守数。输入格式:输入在第一行中给出正整数 M(≤20),随后一行给出...原创 2019-01-14 12:03:01 · 405 阅读 · 0 评论 -
1088 三人行 (PAT 乙级 中文 C/C++语言)
1088 三人行 (20 point(s))子曰:“三人行,必有我师焉。择其善者而从之,其不善者而改之。”本题给定甲、乙、丙三个人的能力值关系为:甲的能力值确定是 2 位正整数;把甲的能力值的 2 个数字调换位置就是乙的能力值;甲乙两人能力差是丙的能力值的 X 倍;乙的能力值是丙的 Y 倍。请你指出谁比你强应“从之”,谁比你弱应“改之”。输入格式:输入在一行中给出三个数,依次为:M...原创 2019-01-10 17:12:03 · 345 阅读 · 0 评论 -
1087 有多少不同的值 (PAT 乙级 中文 C/C++语言)
1087 有多少不同的值 (20 point(s))当自然数 n 依次取 1、2、3、……、N 时,算式 ⌊n/2⌋+⌊n/3⌋+⌊n/5⌋ 有多少个不同的值?(注:⌊x⌋ 为取整函数,表示不超过 x 的最大自然数,即 x 的整数部分。)输入格式:输入给出一个正整数 N(2≤N≤104)。输出格式:在一行中输出题面中算式取到的不同值的个数。输入样例:2017...原创 2019-01-10 15:58:36 · 273 阅读 · 0 评论 -
1086 就不告诉你 (PAT 乙级 中文 C/C++语言)
1086 就不告诉你 (15 point(s))做作业的时候,邻座的小盆友问你:“五乘以七等于多少?”你应该不失礼貌地围笑着告诉他:“五十三。”本题就要求你,对任何一对给定的正整数,倒着输出它们的乘积。输入格式:输入在第一行给出两个不超过 1000 的正整数 A 和 B,其间以空格分隔。输出格式:在一行中倒着输出 A 和 B 的乘积。输入样例:5 7输出样例...原创 2019-01-10 12:55:05 · 430 阅读 · 0 评论 -
1093 字符串A+B (PAT 乙级 中文 C/C++语言)
1093 字符串A+B (20 point(s))给定两个字符串 A 和 B,本题要求你输出 A+B,即两个字符串的并集。要求先输出 A,再输出 B,但重复的字符必须被剔除。输入格式:输入在两行中分别给出 A 和 B,均为长度不超过 106的、由可见 ASCII 字符 (即码值为32~126)和空格组成的、由回车标识结束的非空字符串。输出格式:在一行中输出题面要求的 A ...原创 2019-01-10 12:16:35 · 384 阅读 · 0 评论 -
1052 卖个萌(PAT 乙级 C++实现)
1052 卖个萌 (20)(20 point(s)) 萌萌哒表情符号通常由“手”、“眼”、“口”三个主要部分组成。简单起见,我们假设一个表情符号是按下列格式输出的:[左手]([左眼][口][右眼])[右手]现给出可选用的符号集合,请你按用户的要求输出表情。输入格式:输入首先在前三行顺序对应给出手、眼、口的可选符号集。每个符号括在一对方括号[]内。题目保证每个集合都至少有一个...原创 2018-07-28 19:23:41 · 291 阅读 · 0 评论 -
1054 求平均值(PAT 乙级 C++实现)
1054 求平均值 (20)(20 point(s)) 本题的基本要求非常简单:给定N个实数,计算它们的平均值。但复杂的是有些输入数据可能是非法的。一个“合法”的输入是[-1000,1000]区间内的实数,并且最多精确到小数点后2位。当你计算平均值的时候,不能把那些非法的数据算在内。输入格式:输入第一行给出正整数N(<=100)。随后一行给出N个实数,数字间以一个空格分隔。输...原创 2018-07-28 18:22:12 · 341 阅读 · 0 评论 -
1043 输出PATest(PAT 乙级 C++实现)
1043 输出PATest(20)(20 point(s)) 给定一个长度不超过10000的、仅由英文字母构成的字符串。请将字符重新调整顺序,按“PATestPATest....”这样的顺序输出,并忽略其它字符。当然,六种字符的个数不一定是一样多的,若某种字符已经输出完,则余下的字符仍按PATest的顺序打印,直到所有字符都被输出。输入格式:输入在一行中给出一个长度不超过10000的、...原创 2018-07-28 15:41:17 · 145 阅读 · 0 评论 -
1074 宇宙无敌加法器(PAT 乙级 C++实现)
1074 宇宙无敌加法器(20 point(s)) 地球人习惯使用十进制数,并且默认一个数字的每一位都是十进制的。而在 PAT 星人开挂的世界里,每个数字的每一位都是不同进制的,这种神奇的数字称为“PAT数”。每个 PAT 星人都必须熟记各位数字的进制表,例如“……0527”就表示最低位是 7 进制数、第 2 位是 2 进制数、第 3 位是 5 进制数、第 4 位是 10 进制数,等等。每一位...原创 2018-07-28 00:38:40 · 212 阅读 · 0 评论 -
1072 开学寄语(PAT 乙级 C++实现)
1072 开学寄语(20 point(s)) 下图是上海某校的新学期开学寄语:天将降大任于斯人也,必先删其微博,卸其 QQ,封其电脑,夺其手机,收其 ipad,断其 wifi,使其百无聊赖,然后,净面、理发、整衣,然后思过、读书、锻炼、明智、开悟、精进。而后必成大器也!本题要求你写个程序帮助这所学校的老师检查所有学生的物品,以助其成大器。输入格式:输入第一行给出两个正整数 N(≤ ...原创 2018-07-27 23:41:36 · 198 阅读 · 0 评论 -
1068 万绿丛中一点红(PAT 乙级 C++实现)
1068 万绿丛中一点红(20 point(s))对于计算机而言,颜色不过是像素点对应的一个 24 位的数值。现给定一幅分辨率为 M×N 的画,要求你找出万绿丛中的一点红,即有独一无二颜色的那个像素点,并且该点的颜色与其周围 8 个相邻像素的颜色差充分大。输入格式:输入第一行给出三个正整数,分别是 M 和 N(≤ 1000),即图像的分辨率;以及 TOL,是所求像素点与相邻点的颜色差阈...原创 2018-07-27 19:01:51 · 374 阅读 · 0 评论 -
1037 在霍格沃茨找零钱(PAT 乙级 C++实现)
1037 在霍格沃茨找零钱(20)(20 point(s)) 如果你是哈利·波特迷,你会知道魔法世界有它自己的货币系统 —— 就如海格告诉哈利的:“十七个银西可(Sickle)兑一个加隆(Galleon),二十九个纳特(Knut)兑一个西可,很容易。”现在,给定哈利应付的价钱P和他实付的钱A,你的任务是写一个程序来计算他应该被找的零钱。输入格式:输入在1行中分别给出P和A,格式为“Ga...原创 2018-07-27 11:38:42 · 403 阅读 · 0 评论 -
1067 试密码(PAT 乙级 C++实现)
1067 试密码(20 point(s)) 当你试图登录某个系统却忘了密码时,系统一般只会允许你尝试有限多次,当超出允许次数时,账号就会被锁死。本题就请你实现这个小功能。输入格式:输入在第一行给出一个密码(长度不超过 20 的、不包含空格、Tab、回车的非空字符串)和一个正整数 N(≤ 10),分别是正确的密码和系统允许尝试的次数。随后每行给出一个以回车结束的非空字符串,是用户尝试输入...原创 2018-07-26 18:36:54 · 241 阅读 · 0 评论 -
1064 朋友数(PAT 乙级 C++实现)
1064 朋友数(20 point(s))如果两个整数各位数字的和是一样的,则被称为是“朋友数”,而那个公共的和就是它们的“朋友证号”。例如 123 和 51 就是朋友数,因为 1+2+3 = 5+1 = 6,而 6 就是它们的朋友证号。给定一些整数,要求你统计一下它们中有多少个不同的朋友证号。输入格式:输入第一行给出正整数 N。随后一行给出 N 个正整数,数字间以空格分隔。题目保证所...原创 2018-07-26 17:58:56 · 270 阅读 · 0 评论 -
1058 选择题(PAT 乙级 C++实现)
1058 选择题(20 point(s))批改多选题是比较麻烦的事情,本题就请你写个程序帮助老师批改多选题,并且指出哪道题错的人最多。输入格式:输入在第一行给出两个正整数 N(≤ 1000)和 M(≤ 100),分别是学生人数和多选题的个数。随后 M 行,每行顺次给出一道题的满分值(不超过 5 的正整数)、选项个数(不少于 2 且不超过 5 的正整数)、正确选项个数(不超过选项个数的正...原创 2018-07-26 17:00:54 · 459 阅读 · 0 评论 -
1057 数零壹(PAT 乙级 C++实现)
1057 数零壹(20 point(s))给定一串长度不超过 105 的字符串,本题要求你将其中所有英文字母的序号(字母 a-z 对应序号 1-26,不分大小写)相加,得到整数 N,然后再分析一下 N 的二进制表示中有多少 0、多少 1。例如给定字符串 PAT (Basic),其字母序号之和为:16+1+20+2+1+19+9+3=71,而 71 的二进制是 1000111,即有 3 个...原创 2018-07-26 15:31:43 · 286 阅读 · 0 评论 -
1033 旧键盘打字(PAT 乙级 C++实现)
1033 旧键盘打字(20)(20 point(s))旧键盘上坏了几个键,于是在敲一段文字的时候,对应的字符就不会出现。现在给出应该输入的一段文字、以及坏掉的那些键,打出的结果文字会是怎样?输入格式:输入在2行中分别给出坏掉的那些键、以及应该输入的文字。其中对应英文字母的坏键以大写给出;每段文字是不超过10^5^个字符的串。可用的字符包括字母[a-z, A-Z]、数字0-9、以及下划线...原创 2018-07-26 13:29:48 · 457 阅读 · 0 评论 -
1053 住房空置率(PAT 乙级 C++实现)
1053 住房空置率 (20)(20 point(s))在不打扰居民的前提下,统计住房空置率的一种方法是根据每户用电量的连续变化规律进行判断。判断方法如下:在观察期内,若存在超过一半的日子用电量低于某给定的阈值e,则该住房为“可能空置”; 若观察期超过某给定阈值D天,且满足上一个条件,则该住房为“空置”。现给定某居民区的住户用电量数据,请你统计“可能空置”的比率和“空置”比率,即以上两...原创 2018-07-25 23:34:27 · 206 阅读 · 0 评论 -
1059 C语言竞赛(PAT 乙级 C++实现)
1059 C语言竞赛(20 point(s))C 语言竞赛是浙江大学计算机学院主持的一个欢乐的竞赛。既然竞赛主旨是为了好玩,颁奖规则也就制定得很滑稽:0、冠军将赢得一份“神秘大奖”(比如很巨大的一本学生研究论文集……)。 1、排名为素数的学生将赢得最好的奖品 —— 小黄人玩偶! 2、其他人将得到巧克力。给定比赛的最终排名以及一系列参赛者的 ID,你要给出这些参赛者应该获得的奖品。...原创 2018-07-23 16:48:11 · 1126 阅读 · 0 评论 -
1051 复数乘法(PAT 乙级 C++实现)
1051 复数乘法 (15)(15 point(s))复数可以写成(A + Bi)的常规形式,其中A是实部,B是虚部,i是虚数单位,满足i^2^ = -1;也可以写成极坐标下的指数形式(R*e^(Pi)^),其中R是复数模,P是辐角,i是虚数单位,其等价于三角形式 R(cos(P) + isin(P))。现给定两个复数的R和P,要求输出两数乘积的常规形式。输入格式:输入在一行中依次...原创 2018-07-23 15:07:10 · 485 阅读 · 0 评论 -
1049 数列的片段和(PAT 乙级 C++实现)
1049 数列的片段和(20)(20 point(s))给定一个正数数列,我们可以从中截取任意的连续的几个数,称为片段。例如,给定数列{0.1, 0.2, 0.3, 0.4},我们有(0.1) (0.1, 0.2) (0.1, 0.2, 0.3) (0.1, 0.2, 0.3, 0.4) (0.2) (0.2, 0.3) (0.2, 0.3, 0.4) (0.3) (0.3, 0.4) (0....原创 2018-07-23 14:33:23 · 252 阅读 · 0 评论 -
1048 数字加密(PAT 乙级 C++实现)
1048 数字加密(20)(20 point(s))本题要求实现一种数字加密方法。首先固定一个加密用正整数A,对任一正整数B,将其每1位数字与A的对应位置上的数字进行以下运算:对奇数位,对应位的数字相加后对13取余——这里用J代表10、Q代表11、K代表12;对偶数位,用B的数字减去A的数字,若结果为负数,则再加10。这里令个位为第1位。输入格式:输入在一行中依次给出A和B,均为不超过...原创 2018-07-23 13:36:22 · 245 阅读 · 0 评论 -
1078 字符串压缩与解压(PAT 乙级 C++实现)
1078 字符串压缩与解压(20 point(s))文本压缩有很多种方法,这里我们只考虑最简单的一种:把由相同字符组成的一个连续的片段用这个字符和片段中含有这个字符的个数来表示。例如 ccccc 就用 5c 来表示。如果字符没有重复,就原样输出。例如 aba 压缩后仍然是 aba。解压方法就是反过来,把形如 5c 这样的表示恢复为 ccccc。本题需要你根据压缩或解压的要求,对给定字符...原创 2018-07-22 18:18:40 · 313 阅读 · 0 评论 -
1082 射击比赛(PAT 乙级 C++实现)
1082 射击比赛(20 point(s))本题目给出的射击比赛的规则非常简单,谁打的弹洞距离靶心最近,谁就是冠军;谁差得最远,谁就是菜鸟。本题给出一系列弹洞的平面坐标(x,y),请你编写程序找出冠军和菜鸟。我们假设靶心在原点(0,0)。输入格式:输入在第一行中给出一个正整数 N(≤ 10 000)。随后 N 行,每行按下列格式给出:ID x y其中 ID 是运动员的编号(...原创 2018-07-22 16:49:02 · 246 阅读 · 0 评论 -
1083 是否存在相等的差(PAT 乙级 C++实现)
1083 是否存在相等的差(20 point(s))给定 N 张卡片,正面分别写上 1、2、……、N,然后全部翻面,洗牌,在背面分别写上 1、2、……、N。将每张牌的正反两面数字相减(大减小),得到 N 个非负差值,其中是否存在相等的差?输入格式:输入第一行给出一个正整数 N(2 ≤ N ≤ 10 000),随后一行给出 1 到 N 的一个洗牌后的排列,第 i 个数表示正面写了 i 的...原创 2018-07-22 16:31:07 · 138 阅读 · 0 评论 -
1085 PAT单位排行(PAT 乙级 C++实现)
1085 PAT单位排行(25 point(s))每次 PAT 考试结束后,考试中心都会发布一个考生单位排行榜。本题就请你实现这个功能。输入格式:输入第一行给出一个正整数 N(≤105),即考生人数。随后 N 行,每行按下列格式给出一个考生的信息:准考证号 得分 学校其中准考证号是由 6 个字符组成的字符串,其首字母表示考试的级别:B代表乙级,A代表甲级,T代表顶级;...原创 2018-07-22 15:31:02 · 181 阅读 · 0 评论 -
1039 到底买不买(PAT 乙级 C++实现)
1039 到底买不买(20)(20 point(s))小红想买些珠子做一串自己喜欢的珠串。卖珠子的摊主有很多串五颜六色的珠串,但是不肯把任何一串拆散了卖。于是小红要你帮忙判断一下,某串珠子里是否包含了全部自己想要的珠子?如果是,那么告诉她有多少多余的珠子;如果不是,那么告诉她缺了多少珠子。为方便起见,我们用[0-9]、[a-z]、[A-Z]范围内的字符来表示颜色。例如在图1中,第3串是小红...原创 2018-07-17 23:57:36 · 256 阅读 · 0 评论 -
1032 挖掘机技术哪家强(PAT 乙级 C++实现)
1032 挖掘机技术哪家强(20)(20 point(s))为了用事实说明挖掘机技术到底哪家强,PAT组织了一场挖掘机技能大赛。现请你根据比赛结果统计出技术最强的那个学校。输入格式:输入在第1行给出不超过10^5^的正整数N,即参赛人数。随后N行,每行给出一位参赛者的信息和成绩,包括其所代表的学校的编号(从1开始连续编号)、及其比赛成绩(百分制),中间以空格分隔。输出格式:在一...原创 2018-07-17 23:25:11 · 169 阅读 · 0 评论 -
1044 火星数字(PAT 乙级 C++实现)
1044 火星数字(20)(20 point(s))火星人是以13进制计数的:地球人的0被火星人称为tret。 地球人数字1到12的火星文分别为:jan, feb, mar, apr, may, jun, jly, aug, sep, oct, nov, dec。 火星人将进位以后的12个高位数字分别称为:tam, hel, maa, huh, tou, kes, hei, elo, ...原创 2018-07-17 21:49:50 · 344 阅读 · 0 评论 -
1029 旧键盘(PAT 乙级 C++实现)
1029 旧键盘(20)(20 point(s))旧键盘上坏了几个键,于是在敲一段文字的时候,对应的字符就不会出现。现在给出应该输入的一段文字、以及实际被输入的文字,请你列出肯定坏掉的那些键。输入格式:输入在2行中分别给出应该输入的文字、以及实际被输入的文字。每段文字是不超过80个字符的串,由字母A-Z(包括大、小写)、数字0-9、以及下划线“_”(代表空格)组成。题目保证2个字符串均...原创 2018-07-17 03:07:36 · 234 阅读 · 0 评论 -
1028 人口普查(PAT 乙级 C++实现)
1028 人口普查(20)(20 point(s))某城镇进行人口普查,得到了全体居民的生日。现请你写个程序,找出镇上最年长和最年轻的人。这里确保每个输入的日期都是合法的,但不一定是合理的——假设已知镇上没有超过200岁的老人,而今天是2014年9月6日,所以超过200岁的生日和未出生的生日都是不合理的,应该被过滤掉。输入格式:输入在第一行给出正整数N,取值在(0, 10^5^];...原创 2018-07-17 02:16:14 · 323 阅读 · 0 评论 -
1027 打印沙漏(PAT 乙级 C++实现)
1027 打印沙漏(20)(20 point(s))本题要求你写个程序把给定的符号打印成沙漏的形状。例如给定17个“*”,要求按下列格式打印***** *** * ********所谓“沙漏形状”,是指每行输出奇数个符号;各行符号中心对齐;相邻两行符号数差2;符号数先从大到小顺序递减到1,再从小到大顺序递增;首尾符号数相等。给定任意N个符号,不一定能正好组成一个沙漏。要...原创 2018-07-17 01:14:38 · 278 阅读 · 0 评论 -
1046 划拳(PAT 乙级 C++实现)
1046 划拳(15)(15 point(s))划拳是古老中国酒文化的一个有趣的组成部分。酒桌上两人划拳的方法为:每人口中喊出一个数字,同时用手比划出一个数字。如果谁比划出的数字正好等于两人喊出的数字之和,谁就赢了,输家罚一杯酒。两人同赢或两人同输则继续下一轮,直到唯一的赢家出现。下面给出甲、乙两人的划拳记录,请你统计他们最后分别喝了多少杯酒。输入格式:输入第一行先给出一个正整数N...原创 2018-07-17 00:30:03 · 342 阅读 · 0 评论 -
1056 组合数的和(PAT 乙级 C++实现)
1056 组合数的和(15 point(s))给定 N 个非 0 的个位数字,用其中任意 2 个数字都可以组合成 1 个 2 位的数字。要求所有可能组合出来的 2 位数字的和。例如给定 2、5、8,则可以组合出:25、28、52、58、82、85,它们的和为330。输入格式:输入在第一行中给出 N(1 < N < 10),随后一行给出 N 个不同的非 0 个位数字。数字间以空格分隔。输...原创 2018-07-16 02:47:32 · 254 阅读 · 0 评论 -
1061 判断题(PAT 乙级 C++实现)
1061 判断题(15 point(s))判断题的评判很简单,本题就要求你写个简单的程序帮助老师判题并统计学生们判断题的得分。输入格式:输入在第一行给出两个不超过 100 的正整数 N 和 M,分别是学生人数和判断题数量。第二行给出 M 个不超过 5 的正整数,是每道题的满分值。第三行给出每道题对应的正确答案,0 代表“非”,1 代表“是”。随后 N 行,每行给出一个学生的解答。数字间均以空格分隔...原创 2018-07-16 02:28:15 · 286 阅读 · 0 评论