422. 有效的单词方块 🔒
题目描述
给你一个字符串数组 words
,如果它能形成一个有效的 单词方块 ,则返回 true
。
有效的单词方块是指此由字符串数组组成的文字方块的 第 k
行 和 第 k
列所显示的字符串完全相同,其中 0 <= k < max(numRows, numColumns)
。
示例 1:
输入: words = ["abcd","bnrt","crmy","dtye"] 输出: true 解释: 第 1 行和第 1 列都读作 "abcd"。 第 2 行和第 2 列都读作 "bnrt"。 第 3 行和第 3 列都读作 "crmy"。 第 4 行和第 4 列都读作 "dtye"。 因此,它构成了一个有效的单词方块。
示例 2:
输入: words = ["abcd","bnrt","crm","dt"] 输出: true 解释: 第 1 行和第 1 列都读作 "abcd"。 第 2 行和第 2 列都读作 "bnrt"。 第 3 行和第 3 列都读作 "crm"。 第 4 行和第 4 列都读作 "dt"。 因此,它构成了一个有效的单词方块。
示例 3:
输入: words = ["ball","area","read","lady"] 输出: false 解释: 第 3 行读作 "read" 而第 3 列读作 "lead"。 因此,它不构成一个有效的单词方块。
提示:
1 <= words.length <= 500
1 <= words[i].length <= 500
words[i]
仅由小写英文字母组成。
解法
方法一:遍历检查
我们观察发现,只要不满足 $words[i][j] = words[j][i]$,就可以直接返回 false
。
因此,我们只需要遍历每一行,然后检查每一行是否满足 $words[i][j] = words[j][i]$ 即可。注意,如果下标越界,也直接返回 false
。
时间复杂度 $O(n^2)$,其中 $n$ 是 $words$ 的长度。空间复杂度 $O(1)$。
1 2 3 4 5 6 7 8 |
|
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 |
|
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 |
|
1 2 3 4 5 6 7 8 9 10 11 |
|
1 2 3 4 5 6 7 8 9 10 11 12 |
|