1036. 跟奥巴马一起编程(15)-PAT乙级真题

美国总统奥巴马不仅呼吁所有人都学习编程,甚至以身作则编写代码,成为美国历史上首位编写计算机代码的总统。2014年底,为庆祝“计算机科学教育周”正式启动,奥巴马编写了很简单的计算机代码:在屏幕上画一个正方形。现在你也跟他一起画吧!
输入格式:
输入在一行中给出正方形边长N(3<=N<=20)和组成正方形边的某种字符C,间隔一个空格。
输出格式:
输出由给定字符C画出的正方形。但是注意到行间距比列间距大,所以为了让结果看上去更像正方形,我们输出的行数实际上是列数的50%(四舍五入取整)。
输入样例:
10 a
输出样例:
aaaaaaaaaa
a                a
a                a
a                a
aaaaaaaaaa

分析:为了让结果看上去更像正方形,输出的行数实际上是列数的50%(四舍五入取整),列数是N,则行数t = N / 2 + N % 2,表示偶数等于除以2,奇数要除以2加1的意思,这样才能满足四舍五入~首先输出第一行,N个c,然后输出中间t-2行,最左边和最右边为一个c,中间为N-2个空格,最后输出最后一行,N个c~

 

1032. 挖掘机技术哪家强(20)-PAT乙级真题

为了用事实说明挖掘机技术到底哪家强,PAT组织了一场挖掘机技能大赛。现请你根据比赛结果统计出技术最强的那个学校。
输入格式:
输入在第1行给出不超过10^5的正整数N,即参赛人数。随后N行,每行给出一位参赛者的信息和成绩,包括其所代表的学校的编号(从1开始连续编号)、及其比赛成绩(百分制),中间以空格分隔。
输出格式:
在一行中给出总得分最高的学校的编号、及其总分,中间以空格分隔。题目保证答案唯一,没有并列。
输入样例:
6
3 65
2 80
1 100
2 70
3 40
3 0
输出样例:
2 150

分析:用数组a保存每个学校的编号对应的总分,在输入时将每一个分数score累加到学校编号num对应的a[num]中,然后遍历整个数组,将总分最高的学校编号保存在变量 t 中,将最高总分保存在max中,最后输出t和max的值~

 

1031. 查验身份证(15)-PAT乙级真题

一个合法的身份证号码由17位地区、日期编号和顺序编号加1位校验码组成。校验码的计算规则如下:
首先对前17位数字加权求和,权重分配为:{7,9,10,5,8,4,2,1,6,3,7,9,10,5,8,4,2};
然后将计算的和对11取模得到值Z;最后按照以下关系对应Z值与校验码M的值:
Z:0 1 2 3 4 5 6 7 8 9 10
M:1 0 X 9 8 7 6 5 4 3 2
现在给定一些身份证号码,请你验证校验码的有效性,并输出有问题的号码。
输入格式:
输入第一行给出正整数N(<= 100)是输入的身份证号码的个数。随后N行,
每行给出1个18位身份证号码。
输出格式:
按照输入的顺序每行输出1个有问题的身份证号码。这里并不检验前17位是否合理,只检查前17位是否全为数字且最后1位校验码计算准确。如果所有号码都正常,则输出“All passed”。
输入样例1:
4
320124198808240056
12010X198901011234
110108196711301866
37070419881216001X
输出样例1:
12010X198901011234
110108196711301866
37070419881216001X
输入样例2:
2
320124198808240056
110108196711301862
输出样例2:
All passed

分析:isTrue函数判断身份证号是否正常,如果不正常返回false,判断每一个给出的身份证号,如果不正常,就输出这个身份证号,并且置flag=1表示有不正常的号码,如果所有的号码都是正常,即flag依旧等于0,则输出All passed~在isTrue函数中,先判断前17位是否是数字,如果不是,直接return false,如果是,就将当前字符转化为数字并与a[i]相乘,累加在sum中,对于第18位,如果是X要转化为10~比较b[sum%11]和第18位是否相等,如果相等就返回true,不相等就返回false~

1029. 旧键盘(20)-PAT乙级真题

旧键盘上坏了几个键,于是在敲一段文字的时候,对应的字符就不会出现。现在给出应该输入的一段文字、以及实际被输入的文字,请你列出肯定坏掉的那些键。
输入格式:
输入在2行中分别给出应该输入的文字、以及实际被输入的文字。每段文字是不超过80个字符的串,由字母A-Z(包括大、小写)、数字0-9、以及下划线“_”(代表空格)组成。题目保证2个字符串均非空。
输出格式:
按照发现顺序,在一行中输出坏掉的键。其中英文字母只输出大写,每个坏键只输出一次。题目保证至少有1个坏键。
输入样例:
7_This_is_a_test
_hs_s_a_es
输出样例:
7TI

分析:用string的find函数~遍历字符串s1,当当前字符s1[i]不在s2中,它的大写也不在ans中时,将当前字符的大写放入ans中,最后输出ans字符串即可~
ps:感谢github上的@xiaorong61给我发的pull request中strchr()函数带来的灵感~让我想到了曾经用过的string的find函数~

1028. 人口普查(20)-PAT乙级真题

某城镇进行人口普查,得到了全体居民的生日。现请你写个程序,找出镇上最年长和最年轻的人。这里确保每个输入的日期都是合法的,但不一定是合理的——假设已知镇上没有超过200岁的老人,而今天是2014年9月6日,所以超过200岁的生日和未出生的生日都是不合理的,应该被过滤掉。
输入格式:
输入在第一行给出正整数N,取值在(0, 10^5];随后N行,每行给出1个人的姓名(由不超过5个英文字母组成的字符串)、以及按“yyyy/mm/dd”(即年/月/日)格式给出的生日。题目保证最年长和最年轻的人没有并列。
输出格式:
在一行中顺序输出有效生日的个数、最年长人和最年轻人的姓名,其间以空格分隔。
输入样例:
5
John 2001/05/12
Tom 1814/09/06
Ann 2121/01/30
James 1814/09/05
Steve 1967/11/20
输出样例:
3 Tom John

分析:用字符串接收name和birth,如果当前birth >= “1814/09/06″且<= “2014/09/06″,则是有效生日,有效个数cnt++,如果birth >= maxbirth,则更新maxname和maxbirth的值;如果birth <= minbirth,则更新minname和minbirth的值,这里的max和min是指数值上的大小~最后输出cnt,minname和maxname,minname表示最年长的(生日的数值大小最小的),maxname表示最年轻的(生日的数值大小最大的)~

1027. 打印沙漏(20)-PAT乙级真题

本题要求你写个程序把给定的符号打印成沙漏的形状。
例如给定17个“*”,要求按下列格式打印
*****
 ***
   *
 ***
*****
所谓“沙漏形状”,是指每行输出奇数个符号;各行符号中心对齐;相邻两行符号数差2;符号数先从大到小顺序递减到1,再从小到大顺序递增;首尾符号数相等。
给定任意N个符号,不一定能正好组成一个沙漏。要求打印出的沙漏能用掉尽可能多的符号。

输入格式:
输入在一行给出1个正整数N(<=1000)和一个符号,中间以空格分隔。
输出格式:
首先打印出由给定符号组成的最大的沙漏形状,最后在一行中输出剩下没用掉的符号数。
输入样例:
19 *
输出样例:
*****
***
*
***
*****
2

分析:每个沙漏都是从最中间一行行向上下分别扩展一行,每次扩展行都要比之前一层多2个符号,最中间一行只有 1 个符号,假设扩展的层数为 i,则扩展出去的上边需要的所有符号个数为3 + 5 + 7 + … + (2i+1) = (3 + 2i + 1) * i / 2 = i * (i + 2),扩展出去的下边与上边同样多所以乘以2,加上最重要那一行1个符号,所以 总共需要2 * i * (i + 2) + 1个符号,所以i从0到N,找满足(2 * i * (i + 2) + 1) > N的最小的 i,因为符号不能超过N,所以只能扩展出去 i-1 行,用变量row表示从最中间一行需要扩展出去的行数,row = i – 1,接下来开始输出,上面的每一行,对于扩展出去的第 i 层需要输出row – i个空格,接着输出i * 2 + 1个符号c和换行符;对于最中间一行,需要输出row – 1个空格、符号c和换行符;对于下面的每一行,对于扩展出去的第i层,需要输出row-i个空格,接着输出i * 2 + 1个符号c和换行符,因为用掉的符号数为2 * row * (row + 2) + 1,所以最后输出剩下没用掉的符号数为N – (2 * row * (row + 2) + 1)~