LeetCode题练习与总结:存在重复元素Ⅱ--219

2024-09-07 13:12

本文主要是介绍LeetCode题练习与总结:存在重复元素Ⅱ--219,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、题目描述

给你一个整数数组 nums 和一个整数 k ,判断数组中是否存在两个 不同的索引 i 和 j ,满足 nums[i] == nums[j] 且 abs(i - j) <= k 。如果存在,返回 true ;否则,返回 false 。

示例 1:

输入:nums = [1,2,3,1], k = 3
输出:true

示例 2:

输入:nums = [1,0,1,1], k = 1
输出:true

示例 3:

输入:nums = [1,2,3,1,2,3], k = 2
输出:false

提示:

  • 1 <= nums.length <= 10^5
  • -10^9 <= nums[i] <= 10^9
  • 0 <= k <= 10^5

二、解题思路

  • 使用一个哈希表(HashMap)来存储遍历过的数字及其对应的索引。
  • 遍历数组 nums,对于每个元素 nums[i]
    • 检查当前元素是否已经在哈希表中,如果存在,则计算当前索引 i 与哈希表中存储的索引之差的绝对值,如果小于等于 k,则返回 true
    • 如果当前元素不在哈希表中,或者不满足上述条件,则将当前元素及其索引存入哈希表。
  • 如果遍历完整个数组都没有找到满足条件的索引对,则返回 false

三、具体代码

import java.util.HashMap;
import java.util.Map;class Solution {public boolean containsNearbyDuplicate(int[] nums, int k) {Map<Integer, Integer> map = new HashMap<>(); // 哈希表存储元素及其索引for (int i = 0; i < nums.length; i++) {// 检查当前元素是否在哈希表中,并且索引差小于等于kif (map.containsKey(nums[i]) && i - map.get(nums[i]) <= k) {return true;}// 将当前元素及其索引存入哈希表map.put(nums[i], i);}return false; // 遍历完数组没有找到满足条件的索引对}
}

这段代码中,我们使用了一个HashMap来存储数组中的元素和它们对应的索引。当我们遍历数组时,我们首先检查当前元素是否已经在HashMap中,如果是,则检查索引差是否满足条件。如果满足条件,我们返回true。如果不满足,我们将当前元素和它的索引存入HashMap。如果遍历完整个数组都没有找到满足条件的索引对,我们返回false

四、时间复杂度和空间复杂度

1. 时间复杂度
  • 遍历数组 nums 的时间复杂度是 O(n),其中 n 是数组 nums 的长度。
  • 在每次遍历时,我们会在哈希表 map 中进行两个操作:containsKey 和 put。在理想情况下,哈希表的操作时间复杂度是 O(1),这是因为哈希表通过散列函数将键均匀分布到桶中,从而可以在常数时间内访问、插入和删除元素。

综上所述,整体算法的时间复杂度是 O(n),因为每个元素只被处理一次,且每次处理的时间复杂度是 O(1)。

2. 空间复杂度
  • 哈希表 map 的大小取决于数组 nums 中不同元素的数量。在最坏的情况下,如果数组中的所有元素都是唯一的,那么哈希表的大小将与数组 nums 的长度相同,即 O(n)。
  • 哈希表中的每个条目包含一个整数(数组中的元素)和一个整数(索引),因此每个条目的大小是 O(1)。

因此,整体算法的空间复杂度是 O(n),这是因为在最坏的情况下,我们需要存储数组中的所有元素及其索引。

五、总结知识点

  • 类定义 (class 关键字):

    • 定义了一个名为 Solution 的公共类。
  • 方法定义:

    • 定义了一个名为 containsNearbyDuplicate 的公共实例方法,接受一个整数数组 nums 和一个整数 k 作为参数,并返回一个布尔值。
  • 数据结构 (HashMap):

    • 使用了 HashMap,它是 Java 中的一个哈希表实现,用于存储键值对(在本例中是数组元素及其索引)。
  • 循环 (for 循环):

    • 使用了 for 循环来遍历数组 nums
  • 条件判断 (if 语句):

    • 使用了 if 语句来检查是否在哈希表中找到了与当前元素相等的元素,并且索引差满足小于等于 k 的条件。
  • 哈希表操作:

    • 使用了 HashMap 的 containsKey 方法来检查哈希表中是否包含特定的键。
    • 使用了 HashMap 的 get 方法来获取与特定键关联的值。
    • 使用了 HashMap 的 put 方法来将键值对插入到哈希表中。

以上就是解决这个问题的详细步骤,希望能够为各位提供启发和帮助。

这篇关于LeetCode题练习与总结:存在重复元素Ⅱ--219的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1145152

相关文章

Python版本与package版本兼容性检查方法总结

《Python版本与package版本兼容性检查方法总结》:本文主要介绍Python版本与package版本兼容性检查方法的相关资料,文中提供四种检查方法,分别是pip查询、conda管理、PyP... 目录引言为什么会出现兼容性问题方法一:用 pip 官方命令查询可用版本方法二:conda 管理包环境方法

pycharm跑python项目易出错的问题总结

《pycharm跑python项目易出错的问题总结》:本文主要介绍pycharm跑python项目易出错问题的相关资料,当你在PyCharm中运行Python程序时遇到报错,可以按照以下步骤进行排... 1. 一定不要在pycharm终端里面创建环境安装别人的项目子模块等,有可能出现的问题就是你不报错都安装

java中判断json key是否存在的几种方法

《java中判断jsonkey是否存在的几种方法》在使用Java处理JSON数据时,如何判断某一个key是否存在?本文就来介绍三种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的... 目http://www.chinasem.cn录第一种方法是使用 jsONObject 的 has 方法

MyBatis/MyBatis-Plus同事务循环调用存储过程获取主键重复问题分析及解决

《MyBatis/MyBatis-Plus同事务循环调用存储过程获取主键重复问题分析及解决》MyBatis默认开启一级缓存,同一事务中循环调用查询方法时会重复使用缓存数据,导致获取的序列主键值均为1,... 目录问题原因解决办法如果是存储过程总结问题myBATis有如下代码获取序列作为主键IdMappe

MySQL使用EXISTS检查记录是否存在的详细过程

《MySQL使用EXISTS检查记录是否存在的详细过程》EXISTS是SQL中用于检查子查询是否返回至少一条记录的运算符,它通常用于测试是否存在满足特定条件的记录,从而在主查询中进行相应操作,本文给大... 目录基本语法示例数据库和表结构1. 使用 EXISTS 在 SELECT 语句中2. 使用 EXIS

Python中logging模块用法示例总结

《Python中logging模块用法示例总结》在Python中logging模块是一个强大的日志记录工具,它允许用户将程序运行期间产生的日志信息输出到控制台或者写入到文件中,:本文主要介绍Pyt... 目录前言一. 基本使用1. 五种日志等级2.  设置报告等级3. 自定义格式4. C语言风格的格式化方法

JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法

《JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法》:本文主要介绍JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法,每种方法结合实例代码给大家介绍的非常... 目录引言:为什么"相等"判断如此重要?方法1:使用some()+includes()(适合小数组)方法2

如何通过try-catch判断数据库唯一键字段是否重复

《如何通过try-catch判断数据库唯一键字段是否重复》在MyBatis+MySQL中,通过try-catch捕获唯一约束异常可避免重复数据查询,优点是减少数据库交互、提升并发安全,缺点是异常处理开... 目录1、原理2、怎么理解“异常走的是数据库错误路径,开销比普通逻辑分支稍高”?1. 普通逻辑分支 v

Spring 依赖注入与循环依赖总结

《Spring依赖注入与循环依赖总结》这篇文章给大家介绍Spring依赖注入与循环依赖总结篇,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1. Spring 三级缓存解决循环依赖1. 创建UserService原始对象2. 将原始对象包装成工

MySQL中查询和展示LONGBLOB类型数据的技巧总结

《MySQL中查询和展示LONGBLOB类型数据的技巧总结》在MySQL中LONGBLOB是一种二进制大对象(BLOB)数据类型,用于存储大量的二进制数据,:本文主要介绍MySQL中查询和展示LO... 目录前言1. 查询 LONGBLOB 数据的大小2. 查询并展示 LONGBLOB 数据2.1 转换为十