use Trie
็ตๅ็ๆๅ: public WordFilter(String[] words)
ๅ้ขๆพๅๅฎ่ฉ็้จๅ, ๅพ้ข้ฝๆพๅฎๆด็, ็บไป้บผ้ๆจฃๅๅข๏ผ
apple#apple, 'pple#apple', 'ple#apple', 'le#apple', 'e#apple', #apple',
ๆไปฅ f() ๆฏๅฐๆ, input ๅฆๆๆฏ le#ap (suffix + # + prefix
้ๆจฃๅพๅ้ข้ๅงๆฏๅฐ, ๅฐฑๆๅฏไปฅๆฏๅฐๅฐ 'le#ap
ple'
ๅ ็บ็ต็ๆๅ, ๅฐฑๆ่ฎๆ sufixๅ # ๅๅฎ่ฉ ็ๆๆ็ตๅ๏ผ๏ผ๏ผ
T:
WordFilter : O(n*L^2), n is words size, L is each word's len
f:() : O(QL), Q is times of query
S: O(n*L^2)
class WordFilter {
class TrieNode {
Map<Character, TrieNode> sons;
int weight;
TrieNode() {
this.sons = new HashMap<>();
this.weight = weight;
}
}
private TrieNode root;
private void insert(String word, int weight) {
TrieNode node = root;
for (char c : word.toCharArray()) {
node.sons.putIfAbsent(c, new TrieNode());
node = node.sons.get(c);
node.weight = weight;
}
}
public WordFilter(String[] words) {
root = new TrieNode();
for (int i = 0; i < words.length; i++) {
int weight = i;
String word = "{" + words[i];
insert(word, weight);
for (int j = 0; j < word.length(); j++) {
insert(word.substring(j+1) + word, weight);
}
}
}
public int f(String prefix, String suffix) {
TrieNode node = root;
for (char c : (suffix + "{" + prefix).toCharArray()) {
if (node.sons.get(c) == null) {
return -1;
}
node = node.sons.get(c);
}
return node.weight;
}
}
/**
* Your WordFilter object will be instantiated and called as such:
* WordFilter obj = new WordFilter(words);
* int param_1 = obj.f(prefix,suffix);
*/
use HashMap
https://leetcode.com/problems/prefix-and-suffix-search/discuss/110044/Three-ways-to-solve-this-problem-in-Java
ไนๅฏไปฅ็จ hashmap, ไฝ่จๆถ้ซๆ่ฉฒๆถ่ๅพๅ
, ไฝ f() ้ๅธธๅฟซ๏ผO(1) or O(L), ไฝๅจ ๅญไธฒ่ถ
้ทๆ, ๆ่ฉฒๆ hash conflic ๅคชๅด้่็กๆณไฝ็จ...
class WordFilter {
private Map<String, Integer> map;
public WordFilter(String[] words) {
map = new HashMap<>();
for (int w = 0; w < words.length; w++) {
int wordLen = words[w].length();
// [0, wordLen], substring parameter can be 0 (entire String)
// 1 <= words[i].length <= 10, so can have i<=10 this condition
for (int i = 0; i <= 10 && i <= wordLen; i++) {
for (int j = 0; j <= 10 && j <= wordLen; j++) {
// all prefx + # + all suffix
String key = words[w].substring(0, i) + "#" + words[w].substring(wordLen - j);
map.put(key, w);
}
}
}
}
public int f(String prefix, String suffix) {
String wordKey = prefix + "#" + suffix;
return map.containsKey(wordKey) ? map.get(wordKey) : -1;
}
}
/**
hashmap store all prefx + # + all suffix combination
T:
WordFilter: O(nL^2)
f: O(1) or O(L), if hash conflics too heavy
S: O(nL^2)
*/