嘉兴微信网站建设/搜索引擎优化关键词
题目描述:
给定一个字符串数组 words,找到 length(word[i]) * length(word[j]) 的最大值,并且这两个单词不含有公共字母。你可以认为每个单词只包含小写字母。如果不存在这样的两个单词,返回 0。
方法一:
class Solution {
public:int maxProduct(vector<string>& words) {int ans = 0;for (int i = 0; i < words.size(); i++){for (int j = i + 1; j < words.size(); j++){bool flag = true;for (char ch = 'a'; ch <= 'z'; ch++){if (words[i].find(ch) != words[i].npos && words[j].find(ch) != words[j].npos){flag = false;break;}}if (flag){int l = words[i].size() * words[j].size();ans = max(ans, l);}}}return ans;}
};
想了半天没有想到什么小于O(n^2)的方法,就直接两次循环了,利用find()函数来搜寻26个字母是否在某两个单词中都出现过。
方法二(位运算):
class Solution {
public:int maxProduct(vector<string>& words) {int n = words.size();vector<int> mask(n);int ans = 0;for (int i = 0; i < n; i++){for (int j = 0; j < words[i].size(); j++){//用int整型的第0 - 25位分别指代字母'a' - 'z'//这里1 << (words[i][j] - 'a')的意思是,将数字1左移(words[i][j] - 'a')位mask[i] |= 1 << (words[i][j] - 'a'); //对每个单词生成掩码,有哪个字母就将对应的位置上的数字置为1}}for (int i = 0; i < n; i++){for (int j = i + 1; j < n; j++){if ((mask[i] & mask[j]) == 0) //如果两个单词的掩码的与是0,则说明没有公共的字母{int len = words[i].size() * words[j].size();ans = max(ans, len);}}}return ans;}
};
看了题解,发现大都是用的位运算的方法,挺巧妙的一种方法,没用过位运算的话确实很难想到。