【LeetCode每日一题】——2540.最小公共值
创始人
2025-05-30 02:24:10

文章目录

  • 一【题目类别】
  • 二【题目难度】
  • 三【题目编号】
  • 四【题目描述】
  • 五【题目示例】
  • 六【解题思路】
  • 七【题目提示】
  • 八【时间频度】
  • 九【代码实现】
  • 十【提交结果】

一【题目类别】

  • 双指针

二【题目难度】

  • 简单

三【题目编号】

  • 2540.最小公共值

四【题目描述】

  • 给你两个整数数组 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
  • 最后返回结果即可

七【题目提示】

  • 1<=nums1.length,nums2.length<=1051 <= nums1.length, nums2.length <= 10^51<=nums1.length,nums2.length<=105
  • 1<=nums1[i],nums2[j]<=1091 <= nums1[i], nums2[j] <= 10^91<=nums1[i],nums2[j]<=109
  • nums1和nums2都是非降序的。nums1 和 nums2 都是 非降序 的。nums1和nums2都是非降序的。

八【时间频度】

  • 时间复杂度:O(min(m,n))O(min(m,n))O(min(m,n)),其中mmm和nnn分别为传入的两个数组的长度
  • 空间复杂度:O(1)O(1)O(1)

九【代码实现】

  1. Java语言版
class Solution {public int getCommon(int[] nums1, int[] nums2) {int index1 = 0;int index2 = 0;int len1 = nums1.length;int len2 = nums2.length;while(index1 < len1 && index2 < len2){if(nums1[index1] == nums2[index2]){return nums1[index1];}else if(nums1[index1] < nums2[index2]){index1++;}else if(nums1[index1] > nums2[index2]){index2++;}}return -1;}
}
  1. C语言版
int getCommon(int* nums1, int nums1Size, int* nums2, int nums2Size)
{int index1 = 0;int index2 = 0;while(index1 < nums1Size && index2 < nums2Size){if(nums1[index1] == nums2[index2]){return nums1[index1];}else if(nums1[index1] < nums2[index2]){index1++;}else if(nums1[index1] > nums2[index2]){index2++;}}return -1;
}
  1. Python语言版
class Solution:def getCommon(self, nums1: List[int], nums2: List[int]) -> int:len1 = len(nums1)len2 = len(nums2)index1 = 0index2 = 0while index1 < len1 and index2 < len2:if nums1[index1] == nums2[index2]:return nums1[index1]elif nums1[index1] < nums2[index2]:index1+=1elif nums1[index1] > nums2[index2]:index2+=1return -1
  1. C++语言版
class Solution {
public:int getCommon(vector& nums1, vector& nums2) {int index1 = 0;int index2 = 0;int len1 = nums1.size();int len2 = nums2.size();while(index1 < len1 && index2 < len2){if(nums1[index1] == nums2[index2]){return nums1[index1];}else if(nums1[index1] < nums2[index2]){index1++;}else if(nums1[index1] > nums2[index2]){index2++;}}return -1;}
};

十【提交结果】

  1. Java语言版
    在这里插入图片描述

  2. C语言版
    在这里插入图片描述

  3. Python语言版
    在这里插入图片描述

  4. C++语言版
    在这里插入图片描述

相关内容

热门资讯

在pycharm中使用chat... 目录 前言 一、插件安装 二、使用步骤 总结 前言 ChatGPT是目前最强大的AI,...
Codeforces Roun... G. Subsequence Addition 标签 规律、数学 链接 传送门、 结论 当前前缀和小...
算法leetcode|42. ... 文章目录42. 接雨水:样例 1:样例 2:提示ÿ...
【项目设计】负载均衡在线OJ 🎇Linux: 博客主页:一起去看日落吗分享博主的在L...
Java开发 | 重写 | 多... 前言 大家好,我是程序猿爱打拳,今天给大家带来的是面向对象之封装继承多...
【Unity】NavMesh ... 在Unity中,可以使用自带导航系统(Navigation System...
由文心一言发布会引发的思考,聊... 文章目录前言一. 文心一言的试用1.1 文心一言发布会1.2 文心一言图片生成功能试用1.3 文心一...
java线程之Thread类的... Thread类的基本用法1. Thread类的构造方法2. Thread的几个常见属性常见属性线程中...
css实现3D弹性按钮以及bo... box-shadow 在实现案例之前先了解css的阴影属性box-shadow,该属性...
【Linux】基础命令大全、实... 个人简介:Java领域新星创作者;阿里云技术博主、星级博主、专家博主&#...
R语言基础教程4:列表和数据框 文章目录列表数据帧表头 R语言系列:1 编程基础💎2 循环语句...
Git基础知识 Git基础知识前言一、Git基本概念1、分布式版本控制系统--Git2、Git配置命令3、Git原理...
【JavaWeb】MySQL 一、数据库的相关概念 1.数据库(DB) ==存储和管...
CPU 是如何执行程序的 代码写了那么多,你知道 a = 1 + 2 这条代码是怎么被 CPU ...
从产品的角度看缓存 文章目录 1. What——什么是缓存?2. Why——为什么需要使用缓存?2.1 什么是用户体验2...
vivado 开发过程中所遇错...  [Synth 8-4556] 开辟的数组内存空间大小问题 [Synth 8-4556] size...
1.4 K8S入门之POD和网... POD 分类 自主式POD控制器管理的POD 容器 每个容器独立存在,有自己的IP地址...
【二】一起算法---队列:ST... 纸上得来终觉浅,绝知此事要躬行。大家好!我是霜淮子,欢迎订...
在使用fastjson中遇到的... 一、在使用fastjson中遇到的问题 导论:最近在写一个JavaFx项目的时候使用...
HJ31 单词倒排 描述 对字符串中的所有单词进行倒排。 说明: 1、构成单词的字符只有26个大写或小写英...
普通插槽、具名插槽、作用域插槽 插槽 插槽就是子组件提供给父组件的占位符,用slot来表示,父组件可以在...
Go语言必知必会100问题-0... 减少代码的嵌套层数 软件开发中的“心智模型”用于描述开发人员在编码时心理活动,每段代码...
CSRF漏洞的概念、利用方式、... CSRF漏洞1.CSRF的概念1.1 什么是CSRF?1.2 基本攻击流程2.CSRF...
基于springboot开发的... 基于springboot开发的学生考勤管理系统 如需更多资料请前往文章底部获取联系方式 系统设计主要...
cocosCreator 之 ... cocosCreator版本: 3.7 简介 cocosCreator的工作流程是通...
vue2中$set的原理_它对... $set的作用背景动态添加属性,不使用$set动态添加属性,使用$set...
3/19考后总结 时间安排 8:30–8:50 读题,T1 感觉是乱搞题,T2 貌似可以二...
【JavaWeb】JDBC 目录 一、JDBC概述 1 JDBC概念 2 JDBC本质 3 JDBC好处 二,J...
python 多任务 一些概念 1.多任务 简单地说,就是同时可以运行多个任务。打个比方,你一...
基于springboot框架实... 基于springboot框架实现自习室预订系统的设计与实现 开发语言:Java 框架...