Problem: 2744. 最大字符串配对数目
文章目录
- 思路
- 解题方法
- 复杂度
- Code
- 拓展
- 官方解法
- 拓展解释
思路
- 要求返回数组中的反转字符数目;
- 数组中每个元素都是固定的2个长度的小写字符串,且不相同;
- 由不相同可知如果是aa,bb这种类型的必定不会有反转字符串;
解题方法
从后向前遍历暴力对比解题
复杂度
时间复杂度 O ( n 2 ) O(n^2) O(n2)
空间复杂度 O ( n ) O(n) O(n)
Code
class Solution {
public:int maximumNumberOfStringPairs(vector<string>& words) {int count=0;for(int i = words.size()-1;i>0;i--){if(words[i][0]==words[i][1]) continue;for(int j = i-1;j>=0;j--){if(words[i][0]==words[j][1]&&words[i][1]==words[j][0]){count++;break;}}}return count;}
};
拓展
官方解法
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;}
};作者:力扣官方题解
链接:https://leetcode.cn/problems/find-maximum-number-of-string-pairs/solutions/2604698/zui-da-zi-fu-chuan-pei-dui-shu-mu-by-lee-0x0e/
来源:力扣(LeetCode)
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
拓展解释
代码逻辑如下:
- 定义一个类Solution,包含一个公共函数maximumNumberOfStringPairs。
- 在maximumNumberOfStringPairs函数中,首先获取字符串数组words的大小n。
- 初始化变量ans为0,用于记录满足条件的字符串对数量。
- 定义一个无序集合seen,用于存储已经出现过的字符串对的数字形式。
- 遍历字符串数组words的每个字符串words[i],执行以下操作:
a. 判断seen中是否已经包含字符串words[i]的逆序(即words[i][1] * 100 + words[i][0])。如果包含,说明找到了一个满足条件的字符串对,将ans加1。
b. 将字符串words[i]的顺序(即words[i][0] * 100 + words[i][1])插入到seen中,表示已经出现过了。 - 返回ans作为结果,即满足条件的字符串对的最大数量。
注意:在代码中,将字符串转换为数字形式是通过将字符串的第一个字符乘以100加上第二个字符来实现的。这种转换方式是为了方便比较和存储。