(C++哈希02) 四数相加 赎金信

454、四数相加II

用两个for循环记录前两个数组元素两两之间的和,再用两个for循环记录后两个数组元素两两之间的和,四数相加就简化为两数相加,用map来查找结果

cpp 复制代码
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、赎金信

字母的数量是有限的,所以可以用数组来模拟哈希

cpp 复制代码
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)

相关推荐
xlq2232222 分钟前
22.多态(下)
开发语言·c++·算法
CoderYanger26 分钟前
C.滑动窗口-越短越合法/求最长/最大——2958. 最多 K 个重复元素的最长子数组
java·数据结构·算法·leetcode·哈希算法·1024程序员节
却话巴山夜雨时i1 小时前
394. 字符串解码【中等】
java·数据结构·算法·leetcode
haing20191 小时前
使用黄金分割法计算Bezier曲线曲率极值的方法介绍
算法·黄金分割
leoufung1 小时前
LeetCode 230:二叉搜索树中第 K 小的元素 —— 从 Inorder 遍历到 Order Statistic Tree
算法·leetcode·职场和发展
jyyyx的算法博客1 小时前
多模字符串匹配算法 -- 面试题 17.17. 多次搜索
算法
da_vinci_x1 小时前
Sampler AI + 滤波算法:解决 AIGC 贴图“噪点过剩”,构建风格化 PBR 工业管线
人工智能·算法·aigc·材质·贴图·技术美术·游戏美术
惊鸿.Jh1 小时前
503. 下一个更大元素 II
数据结构·算法·leetcode
chao1898442 小时前
MATLAB 实现声纹识别特征提取
人工智能·算法·matlab
zhishidi2 小时前
推荐算法之:GBDT、GBDT LR、XGBoost详细解读与案例实现
人工智能·算法·推荐算法