代码随想录算法训练营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_846341654 分钟前
C++动态链接库开发
开发语言·c++·算法
ZPC821012 分钟前
【无标题】
人工智能·pytorch·算法·机器人
2301_7644413314 分钟前
使用python构建的STAR实验ΛΛ̄自旋关联完整仿真
开发语言·python·算法
Rainy Blue88318 分钟前
前缀和与差分(蓝桥杯高频考点)
数据结构·算法·蓝桥杯
Dfreedom.18 分钟前
机器学习经典算法全景解析与演进脉络(无监督学习篇)
人工智能·学习·算法·机器学习·无监督学习
421!24 分钟前
ESP32学习笔记之GPIO
开发语言·笔记·单片机·嵌入式硬件·学习·算法·fpga开发
夏日听雨眠29 分钟前
数据结构(单循环链表)
数据结构·链表
智算菩萨32 分钟前
【How Far Are We From AGI】4 AGI的“生理系统“——从算法架构到算力基座的工程革命
论文阅读·人工智能·深度学习·算法·ai·架构·agi
福赖34 分钟前
《算法:生产车间》
算法
空空潍43 分钟前
LeetCode力扣 hot100一刷完结
算法·leetcode