LeetCode 面试题 16.24.数对和

设计一个算法,找出数组中两数之和为指定值的所有整数对。一个数只能属于一个数对。

示例 1:

输入:nums = [5,6,5], target = 11

输出:[[5,6]]

示例 2:

输入:nums = [5,6,5,6], target = 11

输出:[[5,6],[5,6]]

提示:

nums.length <= 100000

-105^55 <= nums[i], target <= 105^55

遍历nums,用哈希表记录下来遍历到的元素的出现次数,后边再出现时,就有了一对数对:

cpp 复制代码
class Solution {
public:
    vector<vector<int>> pairSums(vector<int>& nums, int target) {
        vector<vector<int>> ans;
        unordered_map<int, int> cnt;
        for (int i : nums) {
            if (cnt[target - i] == 0) {
                ++cnt[i];
            } else {
                ans.push_back({i, target - i});
                --cnt[target - i];
            }
        }
        return ans;
    }
};

如果nums的长度为n,nums中元素的种类数为m,则此算法时间复杂度为O(n),空间复杂度为O(m)。

相关推荐
yyy(十一月限定版)9 分钟前
matlab矩阵的操作
算法·matlab·矩阵
努力学算法的蒟蒻26 分钟前
day58(1.9)——leetcode面试经典150
算法·leetcode·面试
txinyu的博客41 分钟前
map和unordered_map的性能对比
开发语言·数据结构·c++·算法·哈希算法·散列表
搞笑症患者1 小时前
压缩感知(Compressed Sensing, CS)
算法·最小二乘法·压缩感知·正交匹配追踪omp·迭代阈值it算法
im_AMBER1 小时前
Leetcode 101 对链表进行插入排序
数据结构·笔记·学习·算法·leetcode·排序算法
快手技术1 小时前
AAAI 2026|全面发力!快手斩获 3 篇 Oral,12 篇论文入选!
前端·后端·算法
颜酱1 小时前
前端算法必备:滑动窗口从入门到很熟练(最长/最短/计数三大类型)
前端·后端·算法
做科研的周师兄1 小时前
【MATLAB 实战】栅格数据 K-Means 聚类(分块处理版)—— 解决大数据内存溢出、运行卡顿问题
人工智能·算法·机器学习·matlab·kmeans·聚类
X在敲AI代码1 小时前
leetcodeD3
数据结构·算法
踩坑记录1 小时前
leetcode hot100 560.和为 K 的子数组 medium 前缀和 + 哈希表
leetcode