PAT 4.2 进阶题 - E 答题卡
若答案为 4 位整数(位数不足时在前面补足 0),则前两位为横坐标,后两位为纵坐标。若一题有两小问,则第一问答案为横坐标,第二问答案为纵坐标。若答案为分数,则分子为横坐标,分母为纵坐标。
输入格式:
输入首先在第一行给出两个正整数:2<n≤90 为二维码的规模,即二维码是由 n×n 个小方块组成的大方块,左下角的小方块对应坐标 (1, 1),右上角的小方块对应坐标 (n, n);另一个 m(<n2)是答案的个数。最后 m 行,每行按以下格式之一给出一题的答案:或者是一个不超过 4 位的整数;或者是两小问的答案 答案1;答案2
;或者是一个分数 分子/分母
。这里保证每个答案都可以解析为一个二维码中的方块位置(即不存在超出二维码范围的坐标)。
输出格式:
输出 n 行,每行 n 个字符,空格用 .
表示,涂了答案的黑格用 #
表示。
输入样例:
5 7
205
3;2
4/5
101
3;3
4/3
5;1
输出样例:
.#.#.
.....
..##.
..#..
#...#
个人思路:
需要一个“答题卡”,也就是n*n的char类型数组,注意左下角第一个数字对应坐标为(1,1)
我觉得解决这个题的重点是接受输入的答案,分为三类:普通的整型205、带字符的3;2以及
4/5,由于数字0到9(作为字符的时候)对应的ASCII码是48到57,故我们只可以从字符变换到整型的值用来当数组的角标,所以我想把每一个输入的答案装到一个新的字符数组并判断其中每个元素的ASCII码,
ps:‘/’对应的ASCII码为47 ‘;’对应的ASCII码为58
有以下三种情况:1、存在元素ASCII码等于47;2、存在元素ASCII码等于58
3、所有的元素ASCII码位于48-57,它们分别对应三种输入答案格式,判断完了答案类型剩下的就是转换成数字作为数组下标了,这比较容易实现。
但是实操过后,发现我既需要找到字符数组中第几个数是“/”或“;”,又需要找到第几个元素开始不为0,有点麻烦。