forked from anishLearnsToCode/leetcode-algorithms
-
Notifications
You must be signed in to change notification settings - Fork 0
/
WordPattern.java
30 lines (25 loc) · 915 Bytes
/
WordPattern.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
import java.util.HashMap;
import java.util.HashSet;
import java.util.Map;
import java.util.Set;
public class WordPattern {
public static boolean wordPattern(String pattern, String string) {
Map<Character, String> bijection = new HashMap<>();
Set<String> wordsMappedTo = new HashSet<>();
String[] words = string.split(" ");
if (words.length != pattern.length()) {
return false;
}
for (int index = 0 ; index < pattern.length() ; index++) {
char letter = pattern.charAt(index);
String word = words[index];
if (!bijection.getOrDefault(letter, word).equals(word) ||
(!bijection.containsKey(letter) && wordsMappedTo.contains(word))) {
return false;
}
bijection.put(letter, word);
wordsMappedTo.add(word);
}
return true;
}
}