给你一个整数数组
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 次操作。
解题思路
首先把nums按从小到达排序,然后设置左右指针,向中间移动,再设置一个count进行计数。
若等于 K,则count++;
若小于 K,则移动左指针;
若大于 K,则移动右指针
(因为已经按从小到达排序了,移动做指针是增加和的值,移动右指针是减小和的值
class Solution {
public:
int maxOperations(vector<int>& nums, int k) {
int count=0;
int left=0,right=nums.size()-1;
sort(nums.begin(),nums.end());//排序
while(left<right){
if(nums[left]+nums[right]==k){
++count;
++left;
--right;
}else if(nums[left]+nums[right]>k){
--right;
}else if(nums[left]+nums[right]<k){
++left;
}
}
return count;
}
};