/**
349. 两个数组的交集
给定两个数组,编写一个函数来计算它们的交集。
示例 1:
输入: nums1 = [1,2,2,1], nums2 = [2,2]
输出: [2]
示例 2:
输入: nums1 = [4,9,5], nums2 = [9,4,9,8,4]
输出: [9,4]
说明:
输出结果中的每个元素一定是唯一的。
我们可以不考虑输出结果的顺序。
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/intersection-of-two-arrays
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
*/
#include <iostream>
#include <algorithm>
#include <vector>
using namespace std;
class Solution {
public:
vector<int> intersection(vector<int>& nums1, vector<int>& nums2)
{
sort(nums1.begin(),nums1.end());
sort(nums2.begin(),nums2.end());
for(auto i=nums1.begin(),j=nums2.begin(); i!=nums1.end();) {
auto tmp=i;
if(j==nums2.end()||*i<*j) {
*(i++)=0x7FFFFFFF;
} else if(*i>*j) {
j++;
} else if(*i==*j) {
if(j!=nums2.begin()&&*(j-1)==*j) {
*i=0x7FFFFFFF;
}
i++;
j++;
}
}
for(auto i=nums1.begin();i!=nums1.end();){
if(*i==0x7FFFFFFF){
nums1.erase(i);
i=nums1.begin();
}
else{
i++;
}
}
return nums1;
}
};