给你两个整数数组 nums1 和 nums2 ,它们已经按非降序排序,请你返回两个数组的 最小公共整数 。如果两个数组 nums1 和 nums2 没有公共整数,请你返回 -1 。
如果一个整数在两个数组中都 至少出现一次 ,那么这个整数是数组 nums1 和 nums2 公共 的。
示例 1:
输入:nums1 = [1,2,3], nums2 = [2,4]
输出:2
解释:两个数组的最小公共元素是 2 ,所以我们返回 2 。
示例 2:
输入:nums1 = [1,2,3,6], nums2 = [2,3,4,5]
输出:2
解释:两个数组中的公共元素是 2 和 3 ,2 是较小值,所以返回 2 。
提示:
1 <= nums1.length, nums2.length <= 10^51 <= nums1[i], nums2[j] <= 10^9nums1和nums2都是 非降序 的。
分析:两个数组都是非降序的,分别用两个指针,指向 nums1 和 nums2,当两个指针指向的值相等时,返回这个值,两个指针同时后移一格;nums1 指针指向的值更小时,它后移一步而 nums2 不变;nums2 指针指向的值更小时,它后移一步而 nums1 不变。直到找到一个相等的值或者至少遍历完一个数组返回 -1。
cpp
class Solution {
public:
int getCommon(vector<int>& nums1, vector<int>& nums2) {
int l1=0,l2=0,r1=nums1.size(),r2=nums2.size();
while(l1<r1&&l2<r2)
{
if(nums1[l1]==nums2[l2])return nums1[l1];
else if(nums1[l1]>nums2[l2])l2++;
else l1++;
}
return -1;
}
};