454、四数相加II
用两个for循环记录前两个数组元素两两之间的和,再用两个for循环记录后两个数组元素两两之间的和,四数相加就简化为两数相加,用map来查找结果
class Solution {
public:
int fourSumCount(vector<int>& nums1, vector<int>& nums2, vector<int>& nums3, vector<int>& nums4) {
unordered_map<int,int> map;
for(int i = 0; i < nums1.size(); i++) {
for(int j = 0; j < nums2.size(); j++) {
map[nums1[i] + nums2[j]]++;
}
}
int count = 0;
for(int i = 0; i < nums3.size(); i++) {
for(int j = 0; j < nums4.size(); j++) {
int flag = 0 - nums3[i] - nums4[j];
if(map.find(flag) != map.end()) {
count += map[flag];
}
}
}
return count;
}
};
时间复杂度:O(n*n)
空间复杂度:O(n*n)
383、赎金信
字母的数量是有限的,所以可以用数组来模拟哈希
class Solution {
public:
bool canConstruct(string ransomNote, string magazine) {
int record[26] = {0};
for(int i = 0; i < magazine.length(); i++) {
record[magazine[i] - 'a']++;
}
for(int i = 0; i < ransomNote.length(); i++) {
record[ransomNote[i] - 'a']--;
if(record[ransomNote[i] - 'a'] < 0) {
return false;
}
}
return true;
}
};
时间复杂度:O(n)
空间复杂度:O(1)