代码随想录算法训练营DAY7第三章 哈希表part02

目录

[454. 四数相加 II](#454. 四数相加 II)

[383. 赎金信](#383. 赎金信)

[15. 三数之和](#15. 三数之和)

[18. 四数之和](#18. 四数之和)


454. 四数相加 II

cpp 复制代码
class Solution {
public:
    int fourSumCount(vector<int>& nums1, vector<int>& nums2, vector<int>& nums3, vector<int>& nums4) {
        int ans=0;
        unordered_map<int,int> map;
        int n=nums1.size();
        for(int i=0;i<n;i++){
            for(int j=0;j<n;j++){
                map[nums1[i]+nums2[j]]++;
            }
        }
        for(int i=0;i<n;i++){
            for(int j=0;j<n;j++){
                int t=-(nums3[i]+nums4[j]);
                ans+=map[t];
            }
        }
        return ans;
    }
};

383. 赎金信

cpp 复制代码
class Solution {
public:
    bool canConstruct(string ransomNote, string magazine) {
        unordered_map<char,int> map;
        for(char t:magazine){
            map[t]++;
        }
        for(char t:ransomNote){
            if(map[t]){
                map[t]--;
            }
            else {
                return false;
            }
        }
        return true;
    }
};

15. 三数之和

cpp 复制代码
class Solution {
public:
    vector<vector<int>> threeSum(vector<int>& nums) {
        vector<vector<int>> ans;
        sort(nums.begin(), nums.end());
        for (int i = 0; i < nums.size() - 2; i++) {
            if(nums[i]>0)continue;
            if(i>0&&nums[i]==nums[i-1])continue;
            int t = -nums[i];
            int j = i + 1;
            int k = nums.size() - 1;
            while ( j < k) {
                int sum = nums[j] + nums[k];
                if (sum < t) {
                    j++;
                } else if (sum > t) {
                    k--;
                } else {
                    ans.push_back({nums[i], nums[j], nums[k]});
                    while(j<k&&nums[j]==nums[j+1]){
                        j++;
                    }
                    while(j<k&&nums[k]==nums[k-1]){
                        k--;
                    }
                    j++;
                    k--;
                }
            }
        }
        return ans;
    }
};

18. 四数之和

cpp 复制代码
class Solution {
public:
    vector<vector<int>> fourSum(vector<int>& nums, int target) {
        sort(nums.begin(),nums.end());
        vector<vector<int>> ans;
        int n=nums.size();
        for(int i=0;i<n;i++){
            if(i>0&&nums[i]==nums[i-1])continue;
            for(int j=i+1;j<n;j++){
                if(j>i+1&&nums[j]==nums[j-1])continue;
                long long t=(long long)target-(long long)nums[i]-(long long)nums[j];
                int left=j+1;
                int right=n-1;
                while(left<right){
                    long long sum=nums[left]+nums[right];
                    if(sum<t){
                        left++;
                    }
                    else if(sum>t){
                        right--;
                    }
                    else {
                        ans.push_back({nums[i],nums[j],nums[left],nums[right]});
                        while(left<right&&nums[left]==nums[left+1])left++;
                        while(left<right&&nums[right]==nums[right-1])right--;
                        left++;
                        right--;
                    }
                }
            }
        }
        return ans;
    }
};
相关推荐
2401_857683549 小时前
C++代码静态检测
开发语言·c++·算法
时艰.9 小时前
JVM 垃圾收集器(G1&ZGC)
java·jvm·算法
2401_838472519 小时前
内存泄漏自动检测系统
开发语言·c++·算法
m0_706653239 小时前
基于C++的爬虫框架
开发语言·c++·算法
diediedei9 小时前
嵌入式数据库C++集成
开发语言·c++·算法
君义_noip9 小时前
洛谷 P3388 【模板】割点(割顶)
c++·算法·图论·信息学奥赛·csp-s
xie0510_9 小时前
string模拟实现
开发语言·c++·算法
xuedingbue9 小时前
数据结构与顺序表:高效数据管理秘籍
数据结构·算法·链表
星火开发设计10 小时前
共用体 union:节省内存的特殊数据类型
java·开发语言·数据库·c++·算法·内存
求梦82010 小时前
【力扣hot100题】合并两个有序链表(22)
算法·leetcode·链表