您的位置:首页 > 其它

318. Maximum Product of Word Lengths

2016-03-20 17:15 573 查看
Given a string array
words
, find the maximum value of
length(word[i]) * length(word[j])
where the two words do not share common letters. You may assume that each word will contain only lower case letters. If no such two words exist, return 0.

Example 1:

Given
["abcw", "baz", "foo", "bar", "xtfn", "abcdef"]


Return 16

The two words can be “abcw”, “xtfn”.

Example 2:

Given
["a", "ab", "abc", "d", "cd", "bcd", "abcd"]


Return 4

The two words can be “ab”, “cd”.

Example 3:

Given
["a", "aa", "aaa", "aaaa"]


Return 0

No such pair of words.

https://leetcode.com/discuss/74580/bit-shorter-c

判断两个字符串有没有共同的字符(都是小写字母)

class Solution {
public:
int maxProduct(vector<string>& words) {
int result = 0;
if(words.empty()) return result;
unordered_map<int ,int> maps;
for(auto word : words){
int mask = 0;
for(auto c : word)
mask |= 1<<(c-'a');   //这句是精华,用比特位指示出现某个字符
maps[mask] = max(maps[mask],(int) word.size());
}
for(auto a : maps)
for(auto b : maps){
if(!(a.first & b.first))
result = max(result, a.second*b.second);
}
return result;
}
};
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: