返回介绍

solution / 0400-0499 / 0422.Valid Word Square / README

发布于 2024-06-17 01:04:00 字数 4194 浏览 0 评论 0 收藏 0

422. 有效的单词方块

English Version

题目描述

给你一个单词序列,判断其是否形成了一个有效的单词方块。

有效的单词方块是指此由单词序列组成的文字方块的 第 k 行 和 第 k 列 (0 ≤ _k_ < max(行数, 列数)) 所显示的字符串完全相同。

注意:

  1. 给定的单词数大于等于 1 且不超过 500。
  2. 单词长度大于等于 1 且不超过 500。
  3. 每个单词只包含小写英文字母 a-z

 

示例 1:

输入:
[
  "abcd",
  "bnrt",
  "crmy",
  "dtye"
]

输出:
true

解释:
第 1 行和第 1 列都是 "abcd"。
第 2 行和第 2 列都是 "bnrt"。
第 3 行和第 3 列都是 "crmy"。
第 4 行和第 4 列都是 "dtye"。

因此,这是一个有效的单词方块。

 

示例 2:

输入:
[
  "abcd",
  "bnrt",
  "crm",
  "dt"
]

输出:
true

解释:
第 1 行和第 1 列都是 "abcd"。
第 2 行和第 2 列都是 "bnrt"。
第 3 行和第 3 列都是 "crm"。
第 4 行和第 4 列都是 "dt"。

因此,这是一个有效的单词方块。

 

示例 3:

输入:
[
  "ball",
  "area",
  "read",
  "lady"
]

输出:
false

解释:
第 3 行是 "read" ,然而第 3 列是 "lead"。

因此,这 不是 一个有效的单词方块。

 

解法

方法一:遍历检查

我们观察发现,只要不满足 $words[i][j] = words[j][i]$,就可以直接返回 false

因此,我们只需要遍历每一行,然后检查每一行是否满足 $words[i][j] = words[j][i]$ 即可。注意,如果下标越界,也直接返回 false

时间复杂度 $O(n^2)$,其中 $n$ 是 $words$ 的长度。空间复杂度 $O(1)$。

class Solution:
  def validWordSquare(self, words: List[str]) -> bool:
    m = len(words)
    n = max(len(w) for w in words)
    if m != n:
      return False
    for j in range(n):
      if words[j] != "".join(w[j] for w in words if j < len(w)):
        return False
    return True
class Solution {
  public boolean validWordSquare(List<String> words) {
    int m = words.size();
    for (int i = 0; i < m; ++i) {
      int n = words.get(i).length();
      for (int j = 0; j < n; ++j) {
        if (j >= m || i >= words.get(j).length()) {
          return false;
        }
        if (words.get(i).charAt(j) != words.get(j).charAt(i)) {
          return false;
        }
      }
    }
    return true;
  }
}
class Solution {
public:
  bool validWordSquare(vector<string>& words) {
    int m = words.size();
    for (int i = 0; i < m; ++i) {
      int n = words[i].size();
      for (int j = 0; j < n; ++j) {
        if (j >= m || i >= words[j].size() || words[i][j] != words[j][i]) {
          return false;
        }
      }
    }
    return true;
  }
};
func validWordSquare(words []string) bool {
  m := len(words)
  for i, w := range words {
    for j := range w {
      if j >= m || i >= len(words[j]) || w[j] != words[j][i] {
        return false
      }
    }
  }
  return true
}
function validWordSquare(words: string[]): boolean {
  const m = words.length;
  for (let i = 0; i < m; ++i) {
    const n = words[i].length;
    for (let j = 0; j < n; ++j) {
      if (j >= m || i >= words[j].length || words[i][j] !== words[j][i]) {
        return false;
      }
    }
  }
  return true;
}

方法二

class Solution:
  def validWordSquare(self, words: List[str]) -> bool:
    m = len(words)
    for i, w in enumerate(words):
      for j, c in enumerate(w):
        if j >= m or i >= len(words[j]) or c != words[j][i]:
          return False
    return True

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文