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)。

相关推荐
沐苏瑶3 小时前
Java 搜索型数据结构全解:二叉搜索树、Map/Set 体系与哈希表
java·数据结构·算法
ZoeJoy84 小时前
算法筑基(二):搜索算法——从线性查找到图搜索,精准定位数据
算法·哈希算法·图搜索算法
Alicx.4 小时前
dfs由易到难
算法·蓝桥杯·宽度优先
_日拱一卒4 小时前
LeetCode:找到字符串中的所有字母异位词
算法·leetcode
云泽8085 小时前
深入 AVL 树:原理剖析、旋转算法与性能评估
数据结构·c++·算法
心软小念5 小时前
金三银四,全网最详细的软件测试面试题总结
软件测试·面试·职场和发展
Wilber的技术分享5 小时前
【LeetCode高频手撕题 2】面试中常见的手撕算法题(小红书)
笔记·算法·leetcode·面试
邪神与厨二病5 小时前
Problem L. ZZUPC
c++·数学·算法·前缀和
软件测试媛7 小时前
软件测试常见的面试题(46道)
功能测试·面试·职场和发展
梯度下降中7 小时前
LoRA原理精讲
人工智能·算法·机器学习