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;
    }
};
相关推荐
想吃火锅10051 天前
【leetcode】121.买卖股票的最佳时机js/c++
算法·leetcode·职场和发展
凌波粒1 天前
LeetCode--491.递增子序列(回溯算法)
数据结构·算法·leetcode
退休倒计时1 天前
【每日一题】LeetCode 146. LRU 缓存 TypeScript
算法·leetcode·缓存·typescript
小欣加油1 天前
leetcode3612 用特殊操作处理字符串I
数据结构·c++·算法·leetcode·职场和发展
凌波粒1 天前
LeetCode--90.子集II(回溯算法)
数据结构·算法·leetcode
凌波粒1 天前
LeetCode--46.全排列(回溯算法)
数据结构·算法·leetcode
吃着火锅x唱着歌1 天前
LeetCode 2530.执行K次操作后的最大分数
数据结构·算法·leetcode
sheeta19981 天前
LeetCode 每日一题笔记 日期:2026.06.16 题目:3612. 字符串特殊符号处理
笔记·算法·leetcode
CoderYanger1 天前
A.每日一题:2095. 删除链表的中间节点
java·数据结构·程序人生·leetcode·链表·面试·职场和发展
青山木1 天前
Hot 100 --- 矩阵置零
线性代数·算法·leetcode·矩阵·哈希算法