返回介绍

solution / 0900-0999 / 0966.Vowel Spellchecker / README_EN

发布于 2024-06-17 01:03:32 字数 7807 浏览 0 评论 0 收藏 0

966. Vowel Spellchecker

中文文档

Description

Given a wordlist, we want to implement a spellchecker that converts a query word into a correct word.

For a given query word, the spell checker handles two categories of spelling mistakes:

  • Capitalization: If the query matches a word in the wordlist (case-insensitive), then the query word is returned with the same case as the case in the wordlist.
    • Example: wordlist = ["yellow"], query = "YellOw": correct = "yellow"
    • Example: wordlist = ["Yellow"], query = "yellow": correct = "Yellow"
    • Example: wordlist = ["yellow"], query = "yellow": correct = "yellow"
  • Vowel Errors: If after replacing the vowels ('a', 'e', 'i', 'o', 'u') of the query word with any vowel individually, it matches a word in the wordlist (case-insensitive), then the query word is returned with the same case as the match in the wordlist.
    • Example: wordlist = ["YellOw"], query = "yollow": correct = "YellOw"
    • Example: wordlist = ["YellOw"], query = "yeellow": correct = "" (no match)
    • Example: wordlist = ["YellOw"], query = "yllw": correct = "" (no match)

In addition, the spell checker operates under the following precedence rules:

  • When the query exactly matches a word in the wordlist (case-sensitive), you should return the same word back.
  • When the query matches a word up to capitlization, you should return the first such match in the wordlist.
  • When the query matches a word up to vowel errors, you should return the first such match in the wordlist.
  • If the query has no matches in the wordlist, you should return the empty string.

Given some queries, return a list of words answer, where answer[i] is the correct word for query = queries[i].

 

Example 1:

Input: wordlist = ["KiTe","kite","hare","Hare"], queries = ["kite","Kite","KiTe","Hare","HARE","Hear","hear","keti","keet","keto"]
Output: ["kite","KiTe","KiTe","Hare","hare","","","KiTe","","KiTe"]

Example 2:

Input: wordlist = ["yellow"], queries = ["YellOw"]
Output: ["yellow"]

 

Constraints:

  • 1 <= wordlist.length, queries.length <= 5000
  • 1 <= wordlist[i].length, queries[i].length <= 7
  • wordlist[i] and queries[i] consist only of only English letters.

Solutions

Solution 1

class Solution:
  def spellchecker(self, wordlist: List[str], queries: List[str]) -> List[str]:
    def f(w):
      t = []
      for c in w:
        t.append("*" if c in "aeiou" else c)
      return "".join(t)

    s = set(wordlist)
    low, pat = {}, {}
    for w in wordlist:
      t = w.lower()
      low.setdefault(t, w)
      pat.setdefault(f(t), w)

    ans = []
    for q in queries:
      if q in s:
        ans.append(q)
        continue
      q = q.lower()
      if q in low:
        ans.append(low[q])
        continue
      q = f(q)
      if q in pat:
        ans.append(pat[q])
        continue
      ans.append("")
    return ans
class Solution {
  public String[] spellchecker(String[] wordlist, String[] queries) {
    Set<String> s = new HashSet<>();
    Map<String, String> low = new HashMap<>();
    Map<String, String> pat = new HashMap<>();
    for (String w : wordlist) {
      s.add(w);
      String t = w.toLowerCase();
      low.putIfAbsent(t, w);
      pat.putIfAbsent(f(t), w);
    }
    int m = queries.length;
    String[] ans = new String[m];
    for (int i = 0; i < m; ++i) {
      String q = queries[i];
      if (s.contains(q)) {
        ans[i] = q;
        continue;
      }
      q = q.toLowerCase();
      if (low.containsKey(q)) {
        ans[i] = low.get(q);
        continue;
      }
      q = f(q);
      if (pat.containsKey(q)) {
        ans[i] = pat.get(q);
        continue;
      }
      ans[i] = "";
    }
    return ans;
  }

  private String f(String w) {
    char[] cs = w.toCharArray();
    for (int i = 0; i < cs.length; ++i) {
      char c = cs[i];
      if (c == 'a' || c == 'e' || c == 'i' || c == 'o' || c == 'u') {
        cs[i] = '*';
      }
    }
    return String.valueOf(cs);
  }
}
class Solution {
public:
  vector<string> spellchecker(vector<string>& wordlist, vector<string>& queries) {
    unordered_set<string> s(wordlist.begin(), wordlist.end());
    unordered_map<string, string> low;
    unordered_map<string, string> pat;
    auto f = [](string& w) {
      string res;
      for (char& c : w) {
        if (c == 'a' || c == 'e' || c == 'i' || c == 'o' || c == 'u') {
          res += '*';
        } else {
          res += c;
        }
      }
      return res;
    };
    for (auto& w : wordlist) {
      string t = w;
      transform(t.begin(), t.end(), t.begin(), ::tolower);
      if (!low.count(t)) {
        low[t] = w;
      }
      t = f(t);
      if (!pat.count(t)) {
        pat[t] = w;
      }
    }
    vector<string> ans;
    for (auto& q : queries) {
      if (s.count(q)) {
        ans.emplace_back(q);
        continue;
      }
      transform(q.begin(), q.end(), q.begin(), ::tolower);
      if (low.count(q)) {
        ans.emplace_back(low[q]);
        continue;
      }
      q = f(q);
      if (pat.count(q)) {
        ans.emplace_back(pat[q]);
        continue;
      }
      ans.emplace_back("");
    }
    return ans;
  }
};
func spellchecker(wordlist []string, queries []string) (ans []string) {
  s := map[string]bool{}
  low := map[string]string{}
  pat := map[string]string{}
  f := func(w string) string {
    res := []byte(w)
    for i := range res {
      if res[i] == 'a' || res[i] == 'e' || res[i] == 'i' || res[i] == 'o' || res[i] == 'u' {
        res[i] = '*'
      }
    }
    return string(res)
  }
  for _, w := range wordlist {
    s[w] = true
    t := strings.ToLower(w)
    if _, ok := low[t]; !ok {
      low[t] = w
    }
    if _, ok := pat[f(t)]; !ok {
      pat[f(t)] = w
    }
  }
  for _, q := range queries {
    if s[q] {
      ans = append(ans, q)
      continue
    }
    q = strings.ToLower(q)
    if s, ok := low[q]; ok {
      ans = append(ans, s)
      continue
    }
    q = f(q)
    if s, ok := pat[q]; ok {
      ans = append(ans, s)
      continue
    }
    ans = append(ans, "")
  }
  return
}

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

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

发布评论

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