OD统一机试:找单词
题目
给一个字符串和一个二维字符数组,如果该字符串存在于该数组中,则按字符串的字符顺序输出字符串每个字符所在单元格的位置下标字符串,如果找不到返回字符串N
。
- 需要按照字符串的字符组成顺序搜索,且搜索到的位置必须是相邻单元格,其中“相邻单元格”是指那些水平相邻或垂直相邻的单元格。
- 同一个单元格内的字母不允许被重复使用。
- 假定在数组中最多只存在一个可能的匹配。
输入
- 第 1 行为一个数字
N
指示二维数组在后续输入所占的行数。 - 第 2 行到第
N+1
行输入为一个二维大写字符数组,每行字符用半角,分割。 - 第
N+2
行为待查找的字符串,由大写字符组成。 - 二维数组的大小为
N*N
,0 < N <= 100
。 - 单词长度
K
,0 < K < 1000
。
输出描述
输出一个位置下标字符串,拼接格式为:第 1 个字符行下标+“,”+第 1 个字符列下标+“,”+第 2 个字符行下标+“,”+第 2 个字符列下标…+“,”+第 N 个字符行下标+“,”+第 N 个字符列下标示例 1
示例一
输入
4
A,C,C,F
C,D,E,D
B,E,S,S
F,E,C,A
ACCESS
输出
0,0,0,1,0,2,1,2,2,2,2,3
说明
ACCESS
分别对应二维数组的[0,0]
[0,1]
[0,2]
[1,2]
[2,2]
[2,3]
下标位置
解题思路
本题实现了简单的字符矩阵匹配问题。
通过调用函数 exist 来检查 word 是否存在于矩阵中。exist 函数遍历矩阵的每一个元素,如果发现字符串的第一个字符和该元素相同,就调用 check 函数来检查这个字符串是否存在于以这个元素为起点的四周的位置。
check 函数