给你一个字符串数组 words ,找出并返回 length(words[i]) * length(words[j]) 的最大值,并且这两个单词不含有公共字母。如果不存在这样的两个单词,返回 0 。

    示例 1:

    输入:words = [“abcw”,”baz”,”foo”,”bar”,”xtfn”,”abcdef”]
    输出:16
    解释:这两个单词为 “abcw”, “xtfn”。
    示例 2:

    输入:words = [“a”,”ab”,”abc”,”d”,”cd”,”bcd”,”abcd”]
    输出:4
    解释:这两个单词为 “ab”, “cd”。
    示例 3:

    输入:words = [“a”,”aa”,”aaa”,”aaaa”]
    输出:0
    解释:不存在这样的两个单词。

    1. /**
    2. * @param {string[]} words
    3. * @return {number}
    4. */
    5. var maxProduct = function (words) {
    6. const length = words.length;
    7. const masks = new Array(length).fill(0);
    8. for (let i = 0; i < length; i++) {
    9. const word = words[i];
    10. const wordLength = word.length;
    11. for (let j = 0; j < wordLength; j++) {
    12. masks[i] |= 1 << (word[j].charCodeAt() - 'a'.charCodeAt());
    13. }
    14. }
    15. let maxProd = 0;
    16. for (let i = 0; i < length; i++) {
    17. for (let j = i + 1; j < length; j++) {
    18. if ((masks[i] & masks[j]) === 0) {
    19. maxProd = Math.max(maxProd, words[i].length * words[j].length);
    20. }
    21. }
    22. }
    23. return maxProd;
    24. };

    image.png