力扣(LeetCode)220. 存在重复元素 III(C++)

news2024/9/25 17:22:24

滑动窗口+有序集合

维护滑动窗口,向右扩大右窗口,新数加入有序集合,题目要求abs(nums[i] - nums[j]) <= t ,找两数之差的绝对值小于t,相当于在窗口里找大小尽可能接近的两个数,固定其中一个数(新数),枚举窗口的数,得到另一个数。在有序集合里,可以二分优化枚举,找窗口内,大于等于新数的第一个数,位置x,在有序集合里,小于新数的第一个数的位置是x-1 。这两个数,就是窗口内最接近新数的数。判断abs(*x - nums[j]) <= tabs(*(x-1) - nums[j]) <= t 即可。

提示 : 窗口最大长度 k + 1 k+1 k+1 ,超过这个长度时,需要删除左窗口的值,向右缩小左窗口。

提示 : 使用有序集合的原因:利用有序集合 l o g n logn logn 时间进行插入、删除、查询操作,降低枚举窗口内元素的时间瓶颈。

提示 : 往有序集合里加入无穷大的哨兵,避免边界问题(空集合查询)。

题目描述

pp

核心代码

class Solution {
public:
    bool containsNearbyAlmostDuplicate(vector<int>& nums, int k, int t) {
        typedef long long LL;
        set<LL> S;
        S.insert(1e18),S.insert(-1e18);
        for(int i = 0,j = 0;j<nums.size();j++){
            if(j-i>k) S.erase(S.find(nums[i++]));
            auto x = S.lower_bound(nums[j]);
            if(abs(*(x--) - nums[j])<=t) return true;
            if(abs(*x - nums[j])<=t) return true;
            S.insert(nums[j]);
        }
        return false;
    }
};
  1. 时间复杂度 : O ( n × l o g ( m i n ( n , k ) ) ) O(n\times log(min(n,k))) O(n×log(min(n,k))) n n n 是数字数量,遍历数字的时间复杂度 O ( n ) O(n) O(n) ,维护滑动窗口(有序集合),插入删除和查询的时间复杂度都是 O ( l o g ( m i n ( n , k ) ) ) O(log(min(n,k))) O(log(min(n,k))) ,二者是乘积关系,时间复杂度 O ( n × m i n ( l o g ( n , k ) ) ) O(n\times min(log(n,k))) O(n×min(log(n,k)))
  2. 空间复杂度 : O ( m i n ( n , k ) ) O(min(n,k)) O(min(n,k)) ,滑动窗口的空间复杂度 O ( m i n ( n , k ) ) O(min(n,k)) O(min(n,k))

AC

AC

致语

  • 理解思路很重要!
  • 欢迎读者在评论区留言,墨染看到就会回复的。

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

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

相关文章

进程优先级环境变量进程地址空间

目录 一、进程优先级 1、概念 2、查看 3、其他概念 二、环境变量 1、基本概念 2、常见环境变量 3、查看环境变量的方法 4、和环境变量相关的命令 5、环境变量的组织方式 6、通过系统调用获取或设置环境变量 三、程序地址空间 一、进程优先级 1、概念 cpu资源分配的…

C++优先队列:priority_queue(即时排序队列)

今天我们来讲一下C中对于排序很好的用的东西&#xff1a;优先队列&#xff1a;priority_queue 既然是队列那么先要包含头文件#include <queue>, 它和queue不同的就在于我们可以自定义其中数据的优先级, 让优先级高的排在队列前面,优先出队 优先队列具有队列的所有特性&am…

数据结构---二叉树的各种遍历算法

&#xff08;一&#xff09;基础知识 如图遍历该树&#xff0c;常见有四种方法&#xff1a; 先根遍历&#xff1a;即先序遍历(Pre-order)&#xff0c;按照根左右的顺序沿一定路径经过路径上所有的结点。在二叉树中&#xff0c;先根后左再右。巧记&#xff1a;根左右。 以标准…

Redis 主从复制实现

1. 前言 今天从实用的角度来分析下 服务器间的主从部署&#xff0c;以及主从复制备份 2. 配置 一个服务器不同的端口代表不同的Redis实例端口6379 表示一台Redis主节点端口6380 表示一台Redis从节点&#xff0c;主节点的端口是6379端口6381 表示一台Redis从节点&#xff0c;主…

Type-challenges:00009-medium-deepReadonly

Implement a generic DeepReadonly<T> which make every parameter of an object - and its sub-objects recursively - readonly. https://github.com/TIMPICKLE/type-challenges/blob/main/questions/00009-medium-deep-readonly/README.md 虽然是medium&#xff0c;但…

图论(2)单源最短路的综合应用

活动 - AcWing 1.acwing1135 从自己家出发摆放其他亲戚&#xff0c;拜访顺序任意。 枚举所有摆放顺序求最小值即可。因此需要每个亲戚家到其他亲戚家的最短路。分别跑出来即可 #include<iostream> #include<algorithm> #include<cstring> #include<que…

pytorch批量计算数据集的均值和方差

from torchvision.transforms import ToTensor#用于把图片转化为张量 import numpy as np#用于将张量转化为数组&#xff0c;进行除法 from torchvision.datasets import ImageFolder#用于导入图片数据集means [0,0,0] std [0,0,0]#初始化均值和方差 transformToTensor()#可将…

UIVM项目验证—数据多通道整形器(MCDF)

1、项目介绍-MCDF MCDF(Multi-Channel Data Formatter)多通道数据整形器将上行多个通道数据存入FIFO&#xff0c;经过Arbiter仲裁&#xff0c;完成指定通道的数据打包&#xff0c;寄存器可以控制各个通道的开关、优先级以及数据包长度。 2、设计描述 CDF设计结构描述如下所示…

红队隧道应用篇之SSH端口转发突破内网(六)

前言 什么是SSH隧道 SSH隧道是使用SSH协议连接两台计算机之间的通道。它使用密钥加密数据传输&#xff0c;并允许计算机之间的安全连接。 通常&#xff0c;SSH隧道用于通过不安全的网络&#xff08;例如互联网&#xff09;连接到远程服务器。隧道提供了一种安全的方法来访问…

我眼中的并发编程

在并发编程中都避不开原子性&#xff0c;可见性&#xff0c;有序性问题。这三个问题都是人们抽象出来&#xff0c;而实际上对应的就是缓存一致性&#xff0c;处理器优化&#xff0c;指令重排序问题。 原子性&#xff1a; 就是一个操作中CPU不可以在中途展厅然后再调度&#xf…

读者写者模型自旋锁(了解)

文章目录读者写者模型&#xff1a;1. 基本理论消费者生产者模型的321原则2. 操作3.理解4. 优先级挂起等待特性的锁 VS 自旋锁线程访问临界资源花费的时间问题&#xff1a;线程如何得知会在临界资源中等待的时间呢&#xff1f;自旋锁的使用读者写者模型&#xff1a; 1. 基本理论…

Python实现FA萤火虫优化算法优化支持向量机回归模型(SVR算法)项目实战

说明&#xff1a;这是一个机器学习实战项目&#xff08;附带数据代码文档视频讲解&#xff09;&#xff0c;如需数据代码文档视频讲解可以直接到文章最后获取。 1.项目背景 萤火虫算法&#xff08;Fire-fly algorithm&#xff0c;FA&#xff09;由剑桥大学Yang于2009年提出 , 作…

ModBus协议学习

之前没接触过&#xff0c;记录一下抄的东西。 Modbus 一个工业上常用的通讯协议、一种通讯约定。Modbus协议包括RTU、ASCII、TCP。其中MODBUS-RTU最常用&#xff0c;比较简单&#xff0c;比较容易实现。 先来简单分析一条MODBUS-RTU报文&#xff0c;例如&#xff1a;01 06 0…

Spring Boot 构建多租户SaaS平台核心技术指南

1. 概述 笔者从2014年开始接触SaaS&#xff08;Software as a Service&#xff09;&#xff0c;即多租户&#xff08;或多承租&#xff09;软件应用平台&#xff1b;并一直从事相关领域的架构设计及研发工作。机缘巧合&#xff0c;在笔者本科毕业设计时完成了一个基于SaaS的高…

绘制一张透明背景的单色位图

在上一篇文章中&#xff0c;我留下了一个谜题&#xff1a;如何使用透明背景绘制一张单色位图。今天我们来揭晓谜底。 丑话说前头&#xff0c;我不是一名 GDI 方面的专家&#xff0c;所以&#xff0c;除了下面讲述的两种方法之外&#xff0c;可能还有我所不知道的更好的解决方案…

九、Map接口和常用方法

文章目录框架特点常用方法六大遍历方式练习框架 数据是K-V类型的我们之前学的几个Set底层也是封装了Map&#xff0c;但是Value部分用默认值&#xff0c;我们只使用Key部分 特点 注意&#xff1a;这里讲的是JDK8的Map接口特点 Map用于保存具有映射关系的数据&#xff1a;Key-…

c++类和对象

二、c类和对象 1.什么是类 c当中类是一个数据类型&#xff0c;封装了数据以及操作。个人理解&#xff1a;c类就是对事物的的抽象&#xff0c;c万物即可为类&#xff0c;和c语言的结构体一样&#xff0c;是一系列事物的共同属性和行为 2.什么是对象 对象就是类的具体化(实例化)…

git创建远程分支并关联本地分支

场景一&#xff1a; 本地、远程都没有分支 "v1.0.0" 1. 先查看确认一下&#xff0c;命令&#xff1a; git branch -a 2. 创建本地分支&#xff0c;命令&#xff1a; git checkout -b v1.0.0 3. 创建远程分支&#xff0c;并且本地分支关联远程分支&#xff0c;命令…

上海亚商投顾:沪指缩量跌0.44% 医药股全线反弹

上海亚商投顾前言&#xff1a;无惧大盘大跌&#xff0c;解密龙虎榜资金&#xff0c;跟踪一线游资和机构资金动向&#xff0c;识别短期热点和强势个股。 市场情绪大小指数今日走势分化&#xff0c;沪指全天弱势震荡&#xff0c;创业板指盘中涨超1%&#xff0c;午后涨幅有所回落。…

2022-12-29 驱动-IO多路复用

IO多路复用的原理&#xff1a; 1>select和poll原理&#xff1a;将文件描述符添加到集合中&#xff0c;监测是否有准备就绪的文件描述符&#xff0c;将未准备就绪的文件描述符剔除集合&#xff0c;准备就绪的文件描述符实现相关操作 2>对于epoll函数原理&#xff1a;创建…