leetcode 2540. 最小公共值 简单

给你两个整数数组 nums1nums2 ,它们已经按非降序排序,请你返回两个数组的 最小公共整数 。如果两个数组 nums1nums2 没有公共整数,请你返回 -1

如果一个整数在两个数组中都 至少出现一次 ,那么这个整数是数组 nums1nums2 公共 的。

示例 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^5
  • 1 <= nums1[i], nums2[j] <= 10^9
  • nums1nums2 都是 非降序 的。

分析:两个数组都是非降序的,分别用两个指针,指向 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;
    }
};
相关推荐
洛水水5 小时前
【力扣100题】53.最长回文子串
算法·leetcode·职场和发展
过期动态6 小时前
【LeetCode 热题 100】盛最多水的容器
java·数据结构·spring boot·算法·leetcode·spring cloud·职场和发展
凌波粒7 小时前
LeetCode--700.二叉搜索树中的搜索(二叉树)
算法·leetcode·职场和发展
洛水水7 小时前
【力扣100题】58.轮转数组
算法·leetcode
风筝在晴天搁浅7 小时前
阿里 LeetCode 876.链表的中间节点
算法·leetcode·链表
玖釉-7 小时前
二叉树展开为链表:从先序遍历到原地指针重排
c++·windows·算法·leetcode·链表
洛水水8 小时前
【力扣100题】52.最小路径和
算法·leetcode
圣保罗的大教堂8 小时前
leetcode 3043. 最长公共前缀的长度 中等
leetcode
菜菜的顾清寒11 小时前
力扣HOT100(34)图论-岛屿数量
算法·leetcode·图论