题目描述:
给你一个下标从 0 开始的数组
words
,数组中包含 互不相同 的字符串。如果字符串
words[i]
与字符串words[j]
满足以下条件,我们称它们可以匹配:
- 字符串
words[i]
等于words[j]
的反转字符串。0 <= i < j < words.length
请你返回数组
words
中的 最大 匹配数目。注意,每个字符串最多匹配一次。
解法一:枚举
二重循环,枚举给定的数组 words 中的 words[i] 和 words[j]是否可以匹配
class Solution {
public:
int maximumNumberOfStringPairs(vector<string>& words) {
int n = words.size();
int ans = 0;
for (int i = 0; i < n; ++i) {
for (int j = i + 1; j < n; ++j) {
if (words[i][0] == words[j][1] && words[i][1] == words[j][0]) {
++ans;
}
}
}
return ans;
}
};
解法二:哈希集合
借助哈希集合,使用vector和set容器解决问题
class Solution {
public:
int maximumNumberOfStringPairs(vector<string>& words) {
int n = words.size();
int ans = 0;
unordered_set<int> seen;
for (int i = 0; i < n; ++i) {
if (seen.count(words[i][1] * 100 + words[i][0])) {
++ans;
}
seen.insert(words[i][0] * 100 + words[i][1]);
}
return ans;
}
};
解法三:哈希通用解法,字符串长度可以随意
class Solution {
public:
int maximumNumberOfStringPairs(vector<string>& words) {
int ans = 0;
unordered_set<string> occ;
for (auto& word : words) {
string tmp = word;
reverse(tmp.begin(), tmp.end());
if (occ.count(tmp)) {
ans++;
}
occ.insert(word);
}
return ans;
}
};