LeetCode题练习与总结:存在重复元素Ⅲ--220

一、题目描述

给你一个整数数组 nums 和两个整数 indexDiff 和 valueDiff 。

找出满足下述条件的下标对 (i, j)

  • i != j,
  • abs(i - j) <= indexDiff
  • abs(nums[i] - nums[j]) <= valueDiff

如果存在,返回 true ;否则,返回 false 

示例 1:

输入:nums = [1,2,3,1], indexDiff = 3, valueDiff = 0
输出:true
解释:可以找出 (i, j) = (0, 3) 。
满足下述 3 个条件:
i != j --> 0 != 3
abs(i - j) <= indexDiff --> abs(0 - 3) <= 3
abs(nums[i] - nums[j]) <= valueDiff --> abs(1 - 1) <= 0

示例 2:

输入:nums = [1,5,9,1,5,9], indexDiff = 2, valueDiff = 3
输出:false
解释:尝试所有可能的下标对 (i, j) ,均无法满足这 3 个条件,因此返回 false 。

提示:

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

二、解题思路

  1. 遍历数组 nums,对于每个元素 nums[i],在它的后面寻找满足条件的元素 nums[j]
  2. 使用一个大小为 indexDiff + 1 的滑动窗口来维护可能满足条件的元素。
  3. 在滑动窗口中,使用一个有序的数据结构(如TreeSet)来维护窗口内的元素,这样可以通过二分查找来快速判断是否存在满足条件的元素。
  4. 对于每个元素 nums[i],在有序集合中查找大于等于 nums[i] - valueDiff 且小于等于 nums[i] + valueDiff 的元素。
  5. 如果找到了满足条件的元素,则返回 true
  6. 如果遍历完数组都没有找到满足条件的元素对,则返回 false

三、具体代码

import java.util.TreeSet;class Solution {public boolean containsNearbyAlmostDuplicate(int[] nums, int indexDiff, int valueDiff) {TreeSet<Long> window = new TreeSet<>();for (int i = 0; i < nums.length; i++) {// 移除窗口外的元素if (i > indexDiff) {window.remove((long) nums[i - indexDiff - 1]);}// 查找是否存在满足条件的元素Long ceiling = window.ceiling((long) nums[i] - valueDiff);if (ceiling != null && ceiling - nums[i] <= valueDiff) {return true;}// 将当前元素添加到窗口中window.add((long) nums[i]);}return false;}
}

在这段代码中,我们使用 TreeSet 来维护一个大小为 indexDiff + 1 的滑动窗口。在每次迭代中,我们首先移除窗口外的元素,然后查找窗口内是否存在满足条件的元素。如果找到了,则返回 true。如果没有找到,我们将当前元素添加到窗口中,并继续下一次迭代。如果遍历完数组都没有找到满足条件的元素对,则返回 false

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

1. 时间复杂度
  • 对于数组 nums 中的每个元素,我们最多执行以下操作一次:

    • 移除窗口外的元素:这是 TreeSet 的 remove 操作,其时间复杂度为 O(log k),其中 k 是 TreeSet 的大小,在本例中 k 等于 indexDiff + 1
    • 查找是否存在满足条件的元素:这是 TreeSet 的 ceiling 操作,其时间复杂度也是 O(log k)。
    • 将当前元素添加到窗口中:这是 TreeSet 的 add 操作,其时间复杂度为 O(log k)。
  • 由于数组 nums 的长度为 n,因此上述每个操作总共执行 n 次。

综上所述,总的时间复杂度为 O(n * log k),其中 k 是滑动窗口的大小,即 indexDiff + 1。由于 k 是一个常数,因此我们可以将其视为 O(log n),所以总的时间复杂度可以简化为 O(n * log n)。

2. 空间复杂度
  • 我们使用了一个 TreeSet 来维护滑动窗口中的元素,其大小最多为 indexDiff + 1

  • 因此,空间复杂度主要取决于 TreeSet 的大小,为 O(k),其中 k 是 indexDiff + 1

由于 indexDiff 是一个给定的常数,因此空间复杂度可以简化为 O(1),即常数空间复杂度。

五、总结知识点

  • 类定义

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

    • public boolean containsNearbyAlmostDuplicate(...) {...}:定义了一个公共方法 containsNearbyAlmostDuplicate,它返回一个布尔值。
  • 数据结构

    • TreeSet<Long>:使用 TreeSet 来存储一个有序集合,它基于红黑树实现,可以保持元素的排序状态。
  • 基本类型与包装类型

    • int[] nums:使用基本类型 int 的数组来存储输入的整数序列。
    • Long:在 TreeSet 中使用包装类型 Long 而不是基本类型 long,因为 TreeSet 不支持基本类型。
  • 循环结构

    • for (int i = 0; i < nums.length; i++) {...}:使用 for 循环来遍历数组 nums
  • 条件语句

    • if (i > indexDiff) {...}:使用 if 语句来检查是否需要移除窗口外的元素。
  • 集合操作

    • window.remove(...):从 TreeSet 中移除一个元素。
    • window.ceiling(...):在 TreeSet 中查找大于等于给定值的最小元素(即天花板)。
    • window.add(...):向 TreeSet 中添加一个元素。
  • 类型转换

    • (long) nums[i]:将 int 类型的数组元素转换为 long 类型,以避免在比较时可能出现的整数溢出。
  • 逻辑运算

    • ceiling != null && ceiling - nums[i] <= valueDiff:使用逻辑与运算符来检查是否找到满足条件的元素。
  • 方法返回

    • return true:当找到满足条件的元素对时,提前返回 true
    • return false:如果没有找到满足条件的元素对,在遍历结束后返回 false
  • 数学运算

    • ceiling - nums[i]:进行减法运算以检查两个元素的差值是否在允许的范围内。

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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.xdnf.cn/news/1527577.html

如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!

相关文章

【国赛急救包】数模国赛查重规则及降重技巧

国赛已经快接近尾声了&#xff0c;各位宝宝论文写得怎么样啦~ 今天为大家分享关于国赛查重的一些规则&#xff0c;以及降重技巧&#xff01;快收藏起来吧~ 1. 国赛查重要求及如何查重 • 数学建模国赛的查重除了知网数据库以外&#xff0c;更重要的是自建库的查重比对&#x…

vLLM (4) - LLMEngine上篇

系列文章目录 vLLM (1) - Qwen2推理&部署 vLLM (2) - 架构总览 vLLM (3) - Sequence & SequenceGroup vLLM (4) - LLMEngine上篇 vLLM (5) - LLMEngine下篇 文章目录 系列文章目录前言一、类图二、LLM三、LLMEngine四、GPUExectuor五、Worker六、ModelRunner七、Cache…

windows下使用vscode编写运行以及调试C/C++

vscode支持类似于vs的断点调试c/c&#xff0c;也可以直接编译&运行c/c 先是编译运行 c/c的方法 微软官方起初设定的科学做法(这也是现在的科学做法)是通过在vscode集成控制台写命令行的方式来实现编译运行程序的,但也可以通过code runner插件…

软件工程-图书管理系统的概要设计

软件概要设计说明书 目录 软件概要设计说明书 一、引言 1.1 编写目的 1.2 背景 1.3 定义 1.3.1特定对象 1.3.2专业术语 1.4 参考资料 二、总体设计 2.1 需求规定 2.1.1信息要求 2.1.2功能要求 2.2 运行环境 2.3 基本概要设计和处理流程 2.4 体系结构设计 2.5 模…

网络安全运维培训一般多少钱

在当今数字化时代&#xff0c;网络安全已成为企业和个人关注的焦点。而网络安全运维作为保障网络安全的重要环节&#xff0c;其专业人才的需求也日益增长。许多人都对网络安全运维培训感兴趣&#xff0c;那么&#xff0c;网络安全运维培训一般多少钱呢? 一、影响网络安全运维培…

C++ | 单例设计模式(懒汉式单例模式源码|饿汉式单例模式)

点击上方"蓝字"关注我们 01、概念 >>> 单例设计模式&#xff08;Singleton Pattern&#xff09;是一种创建型设计模式&#xff0c;确保一个类只有一个实例&#xff0c;并提供一个全局访问点来访问该实例。单例模式通常用于需要在整个应用程序中共享一个对象…

让中学生也能一下子认识5000年都无人能识的无穷大自然数

黄小宁 5000多年来数学一直未能证明存在>N一切数的标准无穷大自然数及其倒数&#xff0c;从而一直否定存在这类数&#xff0c;正如西医否定人体存在经络系统那样。 x轴各元点的坐标x变为的有序数对 ( x , y2 x)是平面点p的坐标&#xff0c;点p的全体是直线y2x。 x可变成一…

PMP–冲刺–十大领域易考点三大项目流程敏捷中的角色职责与3个工件高频考点考试技巧–名词解析版

文章目录 技巧PMBOK易考点--题干关键词一、引论二、项目运行环境三、项目经理的角色四、整合管理五、范围管理六、进度管理七、成本管理八、质量管理九、资源管理十、沟通管理十一、风险管理十二、采购管理十三、干系人管理 考试中的三大项目流程一 、变更流程二 、风险流程三 …

最大括号深度

题目描述 现有一字符串仅由(&#xff0c;)&#xff0c;{&#xff0c;}&#xff0c;[&#xff0c;]六种括号组成。 若字符串满足以下条件之一&#xff0c;则为无效字符串: ①任一类型的左右括号数量不相等;②存在未按正确顺序(先左后右)闭合的括号。 输出括号的最大嵌套深度&…

卷积神经网络-经典分类网络结构(LetNet-5,AlexNet)

目录 一:LeNet-5解析 1.网络结构 输入层: 1.conv1: 2.pool1层: 3.conv2: 4.pool2: 5.fc3,fc4: 6.output层: 2.参数形状 二:AlexNet 1层: 2层: 3层: 4 层 5 层 6 全连接层 7 全连接层 8 全连接层 三:卷积网络结构的优化: 1.常见结构特点: …

【Python篇】PyQt5 超详细教程——由入门到精通(中篇二)

文章目录 PyQt5超详细教程前言第7部分&#xff1a;生成图表与数据可视化7.1 matplotlib 与 PyQt5 的结合7.2 在 PyQt5 中嵌入 matplotlib 图表示例 1&#xff1a;嵌入简单的 matplotlib 图表代码详解&#xff1a; 7.3 动态生成图表示例 2&#xff1a;动态更新图表代码详解&…

《战锤40K:星际战士2》超越《黑神话》 登Steam热销榜首

《使命召唤&#xff1a;黑色行动6》将登陆 PC Game Pass看来确实影响了销量&#xff0c;因为这次在 Steam 上它的预购并没有占领 Steam 热销榜单之首。这次霸榜的则是即将推出的《战锤40K&#xff1a;星际战士2》。 根据 SteamDB 显示&#xff0c;这部将于9 月 10 日发售的游戏…

多个vue项目部署到nginx服务器

文章目录 需求一、项目打包1.vue.config.js2.request.js文件3.打包 二、nginx配置 需求 同一个域名安装多个vue项目。 比如&#xff1a;域名为 https://domain.com 后缀。那么通过不同的后缀就能去访问不同的项目地址。 https://domain.com&#xff0c;不加任何后缀&#x…

使用宝塔面板安装mrdoc

使用宝塔面板安装mrdoc 1、所需环境2、ubuntu系统安装3、宝塔面板安装4、NginxPHPMySQL安装5、python项目管理器安装6、 python版本安装7、mrdoc的部署7.1、下载项目源码7.2、新建python管理器项目 8、使用MySQL作为默认数据库8.1、安装mysqlclient插件8.2、配置数据库连接信息…

设计表时的三大范式(MySQL)

设计表时的三大范式 什么是范式第一范式第二范式不满足第二范式的缺点数据冗余插入异常更新异常删除异常 第三范式 什么是范式 在表的设计中&#xff0c;范式是一种设计规范&#xff0c;用于更好的组织和管理数据。 设计数据表时的范式有第一范式1NF、第二范式2NF、第三范式3…

永远学习:为什么人工智能难以适应新挑战

理解深度学习的局限性并追求真正的持续适应 欢迎来到雲闪世界。 “智者适应环境&#xff0c;正如水适应水瓶。”——中国谚语 “适应或灭亡&#xff0c;现在和以往一样&#xff0c;是大自然的必然法则。”——赫伯特乔治威尔斯 近年来&#xff0c;人工智能取得了长足的进步。所…

认知杂谈54

I I 内容摘要&#xff1a; 这篇内容主要有以下几个要点&#xff1a;首先&#xff0c;沟通不在一个调时可学习人际交往心理学知识、线上课程及关注名师来改善。其次&#xff0c;挑房子、工作、搭档和人生伴侣要谨慎&#xff0c;找心灵相通能共同进步的人。再者&#xff0c;远离…

主窗口的设计与开发(二)

主窗口的设计与开发&#xff08;二&#xff09; 前言 在上一集当中&#xff0c;我们完成了主窗口的初始化&#xff0c;主窗口包括了左中右三个区域。我们还完成了对左窗口的初始化&#xff0c;左窗口包括了用户头像、会话标签页按钮、好友标签页按钮以及好友申请标签页按钮。对…

【英语】前缀 与 后缀

文章目录 前言一、表示否定二、表示方向1. 表示 "前"2. 表示 "后"&#xff0c;"回"3. 低&#xff0c;下4. 高&#xff0c;上&#xff0c;超出&#xff0c;向外5. 表示 “内” 总结参考文献 前言 进行英语前后缀的复习 一、表示否定 a-, ab- amo…

机器学习模型中的因果关系:引入单调约束

单调约束是使机器学习模型可行的关键&#xff0c;但它们仍未被广泛使用欢迎来到雲闪世界。 碳ausality 正在迅速成为每个数据科学家工具包中必不可少的组成部分。 这是有充分理由的。 事实上&#xff0c;因果模型在商业中具有很高的价值&#xff0c;因为它们为“假设”情景提…