每日一道leetcode(补充版)

1679. K 和数对的最大数目 - 力扣(LeetCode)

题目

给你一个整数数组 nums 和一个整数 k 。

每一步操作中,你需要从数组中选出和为 k 的两个整数,并将它们移出数组。

返回你可以对数组执行的最大操作数。

示例 1:

输入:nums = [1,2,3,4], k = 5
输出:2
解释:开始时 nums = [1,2,3,4]:
- 移出 1 和 4 ,之后 nums = [2,3]
- 移出 2 和 3 ,之后 nums = []
不再有和为 5 的数对,因此最多执行 2 次操作。

示例 2:

输入:nums = [3,1,3,4,3], k = 6
输出:1
解释:开始时 nums = [3,1,3,4,3]:
- 移出前两个 3 ,之后nums = [1,4,3]
不再有和为 6 的数对,因此最多执行 1 次操作。

提示:

  • 1 <= nums.length <= 105
  • 1 <= nums[i] <= 109
  • 1 <= k <= 109

思路

  1. 先将数组排序,然后再左右匹配。

代码实现

class Solution {
public:
    int maxOperations(vector& nums, int k) {
        int l = 0, r = nums.size()-1, cnt = 0, sum;
        if (r < 1)
            return 0;
        sort(nums.begin(), nums.end());
        while (l < r) {
            sum = nums[l]+nums[r];
            if (sum == k) {
                l++;
                r--;
                cnt++;
            } 
            else if(sum < k) l++;
            else r--;
        }
        return cnt;
    }
};

复杂度分析

  • 时间复杂度:O(n)。
  • 空间复杂度:O(1)。

其他题解

  • 还有一种方法也挺有意思的,就是利用哈希表,先将nums中的数字情况存入哈希表,然后再遍历一遍数组,每次遇到x时就找哈希表key为k-x是否还可以匹配,可以就将map[k-x]的value减一,然后完成匹配,最后结果除以2即可(因为对应的匹配肯定是成对存在的,所以会重复一次)。
  • 这个时空间复杂度都是O(n)的,所以就不复现了。

你可能感兴趣的:(leetcode训练,leetcode,算法,职场和发展,c++,双指针,哈希算法)