Given a string array words, return the maximum value oflength(word[i]) * length(word[j])where the two words do not share common letters. If no such two words exist, return 0.
Example 1:
**Input:** words = ["abcw","baz","foo","bar","xtfn","abcdef"]
**Output:** 16
**Explanation:** The two words can be "abcw", "xtfn".
Example 2:
**Input:** words = ["a","ab","abc","d","cd","bcd","abcd"]
**Output:** 4
**Explanation:** The two words can be "ab", "cd".
Example 3:
**Input:** words = ["a","aa","aaa","aaaa"]
**Output:** 0
**Explanation:** No such pair of words.
Constraints:
2 <= words.length <= 1000
1 <= words[i].length <= 1000
words[i] consists only of lowercase English letters.
ac
classSolution {publicintmaxProduct(String[] words) {// edge casesif (words.length<=1) return0;// 1) get a bit mask represent letter used for each wordint[] masks =newint[words.length];for (int i =0; i <words.length; i++) {int mask =0;for (char c : words[i].toCharArray()) {int b = c -'a'; mask |=1<< b; } masks[i] = mask; }// 2) check every pair get max productint max =0;for (int i =0; i <words.length-1; i++) {for (int j = i +1; j <words.length; j++) {if ((masks[i] & masks[j]) !=0) continue; // have common letters max =Math.max(max, words[i].length() * words[j].length()); } }return max; }}/*1) get a bit mask represent letter used for each word 2) check every pair get max product*/