LintCode解题思路LintCode解题思路

OJ lintcode 两数组的交 II

2017-02-19  本文已影响1人  DayDayUpppppp

计算两个数组的交
注意事项
每个元素出现次数得和在数组里一样
答案可以以任意顺序给出
您在真实的面试中是否遇到过这个题?
Yes
样例
nums1 = [1, 2, 2, 1], nums2 = [2, 2], 返回 [2, 2].

class Solution {
public:
    /**
     * @param nums1 an integer array
     * @param nums2 an integer array
     * @return an integer array
     */
    vector<int> intersection(vector<int>& nums1, vector<int>& nums2) {
        // Write your code here
        vector<int> result;
        multiset <int> s(nums1.begin(),nums1.end());
        for(auto it=nums2.begin();it!=nums2.end();it++){
            auto ret=s.find((*it));
            if(ret!=s.end()){
                //find
                result.push_back(*ret);
                s.erase(ret);
            }
        }

        return result;

    }
};
上一篇下一篇

猜你喜欢

热点阅读