Leetcode 2454. 下一个更大元素 IV

  • Leetcode 2454. 下一个更大元素 IV
  • 题目
    • 给你一个下标从 0 开始的非负整数数组 nums 。对于 nums 中每一个整数,你必须找到对应元素的 第二大 整数。
    • 如果 nums[j] 满足以下条件,那么我们称它为 nums[i] 的 第二大 整数:
      • j >
      • nums[j] > nums[i]
      • 恰好存在 一个 k 满足 i < k < j 且 nums[k] > nums[i] 。
      • 如果不存在 nums[j] ,那么第二大整数为 -1 。
      • 比方说,数组 [1, 2, 4, 3] 中,1 的第二大整数是 4 ,2 的第二大整数是 3 ,3 和 4 的第二大整数是 -1 。
    • 请你返回一个整数数组 answer ,其中 answer[i]是 nums[i] 的第二大整数。
    • 1 <= nums.length <= 10 ^ 5
    • 0 <= nums[i] <= 10 ^ 9
  • 解法
    • 反向思考 + 两次单调队列 + 排序二分/TreeSet:
    • 第 1 步:
    • 题目可以转化为两步处理,
    • 通过下标 i 先找到 i 右边第一个 nums[k] > nums[i] 的 k,
    • 再存储 i 和 k 在找到 k 右边第一个 nums[j] > nums[i] 的 nums[j]
    • 第 2 步:
    • 找 k 可以使用倒序遍历,
    • 然后使用一个严格递减的单调栈,
    • 每次第一个大于 nums[i] 的 nums 下标即为 k,
      • 因为当求 i-1 时,要么 k 就是之前放入的 i(nums[i-1] < nums[i]),要么就是栈里剩下的某个元素(nums[i-1] >= nums[i])
    • 将所有 i 与 k 均存起来,
    • 第 3 步:
    • 由于求 i-1 时,此时的 k1 可能比求 i 时的 k2 更靠右,此时 j1 就应该在 [0,k1) 对应的单调栈中,
    • 在线求特别麻烦,因此可以考虑离线(即将所有 i-k 存起来,排序后统一处理)
    • 第 4 步:
    • 对 k 降序排,然后再次倒序使用一个严格递减的单调栈,
    • 当遍历的值等于某个 k 时,使用 二分/TreeSet 栈中大于 nums[i] 的最小值,即为结果
    • 遍历单调栈与 k 使用类似双指针的方式处理
    • 第 5 步:
    • 时间复杂度:O(n*logn)排序,空间复杂度:O(n)
  • 代码
/*** 反向思考 + 两次单调队列 + 排序二分/TreeSet:** 第 1 步:* 题目可以转化为两步处理,* 通过下标 i 先找到 i 右边第一个 nums[k] > nums[i] 的 k,* 再存储 i 和 k 在找到 k 右边第一个 nums[j] > nums[i] 的 nums[j]** 第 2 步:* 找 k 可以使用倒序遍历,* 然后使用一个严格递减的单调栈,* 每次第一个大于 nums[i] 的 nums 下标即为 k,*     * 因为当求 i-1 时,要么 k 就是之前放入的 i(nums[i-1] < nums[i]),要么就是栈里剩下的某个元素(nums[i-1] >= nums[i])* 将所有 i 与 k 均存起来,** 第 3 步:* 由于求 i-1 时,此时的 k1 可能比求 i 时的 k2 更靠右,此时 j1 就应该在 [0,k1) 对应的单调栈中,* 在线求特别麻烦,因此可以考虑离线(即将所有 i-k 存起来,排序后统一处理)** 第 4 步:* 对 k 降序排,然后再次倒序使用一个严格递减的单调栈,* 当遍历的值等于某个 k 时,使用 二分/TreeSet 栈中大于 nums[i] 的最小值,即为结果* 遍历单调栈与 k 使用类似双指针的方式处理** 第 5 步:* 时间复杂度:O(n*logn)排序,空间复杂度:O(n)**/public int[] secondGreaterElement(int[] nums) {int n = nums.length;// 所有 i 与 k 均存起来,k 不存在则使用 -1List<Pair<Integer, Integer>> indexList = new ArrayList<>();int[] res = new int[n];// 找 k 可以使用倒序遍历,然后使用一个严格递减的单调栈,Deque<Integer> decreaseStack = new LinkedList<>();for (int i = n - 1; i >= 0; i--) {while (!decreaseStack.isEmpty() && nums[decreaseStack.peekFirst()] <= nums[i]) {decreaseStack.pop();}indexList.add(new Pair<>(i, decreaseStack.isEmpty() ? -1 : decreaseStack.peekFirst()));// k 等于 -1 则结果也为 -1res[i] = -1;decreaseStack.push(i);}// 对 k 降序排,然后再次倒序使用一个严格递减的单调栈Collections.sort(indexList, (o1, o2) -> o2.getValue() - o1.getValue());
//        System.out.println(indexList);// 当遍历的值等于某个 k 时,使用 二分/TreeSet 栈中大于 nums[i] 的最小值,即为结果TreeSet<Integer> treeSet = new TreeSet<>();decreaseStack.clear();int listIndex = 0;for (int i = n - 1; i >= 0 && listIndex < n; i--) {while (listIndex < n && i == indexList.get(listIndex).getValue()) {int numsIndex = indexList.get(listIndex).getKey();Integer resTemp = treeSet.higher(nums[numsIndex]);res[numsIndex] = resTemp == null ? -1 : resTemp;listIndex++;}while (!decreaseStack.isEmpty() && nums[decreaseStack.peekFirst()] <= nums[i]) {treeSet.remove(nums[decreaseStack.peekFirst()]);decreaseStack.pop();}treeSet.add(nums[i]);decreaseStack.push(i);}return res;}

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

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

相关文章

螺旋矩阵算法(leetcode第59题)

题目描述&#xff1a; 给你一个正整数 n &#xff0c;生成一个包含 1 到 n2 所有元素&#xff0c;且元素按顺时针顺序螺旋排列的 n x n 正方形矩阵 matrix 。示例 1&#xff1a;输入&#xff1a;n 3 输出&#xff1a;[[1,2,3],[8,9,4],[7,6,5]] 示例 2&#xff1a;输入&#…

电商API代码如何接入写

要接入一个API&#xff0c;通常需要遵循以下步骤&#xff1a; 1. 【了解API文档】&#xff1a;首先&#xff0c;需要了解你想要接入的API的文档。这些文档通常会包含关于如何使用该API的重要信息&#xff0c;比如基本的请求格式、可用的端点&#xff08;endpoints&#xff09;…

SQL Server ,使用递归查询具有层级关系的数据。

假设我们有一个表格 Employees&#xff0c;其中包含员工的层级关系信息&#xff0c;每一行包括员工的ID、姓名以及上级员工的ID。 下面是一个示例表格及其数据&#xff1a; Employees ---------------------- EmployeeID | Name | ManagerID ---------------------- 1 …

6-46.矩阵运算

根据main函数中矩阵对象的定义与使用&#xff0c;定义相关的矩阵类Array&#xff0c;并利用运算符重载的方法实现矩阵的加法与输入输出操作。&#xff08;为简化问题&#xff0c;矩阵中元素为2位以内整数&#xff0c;要求矩阵按照行列的格式输出&#xff0c;每个元素占3位宽度&…

Process On在线绘制流程图

目录 一.ProcessOn 1.1.介绍 1.2.直接网上使用 二.绘制门诊流程图 三.绘制住院流程图 四.绘制药库采购入库流程图 五.绘制OA会议流程图 今天就到这里了哦!!!希望能帮到你哦&#xff01;&#xff01;&#xff01; 一.ProcessOn 1.1.介绍 ProcessOn&#xff08;流程&#…

MFC 加载本地文件设置图标

基于单文件/多文件版 1、在CMainFrame中设置 int CMainFrame::OnCreate(LPCREATESTRUCT lpCreateStruct) {//...........// 从本地文件加载图标HICON hIcon (HICON)::LoadImage(NULL, L"./vip.ico", IMAGE_ICON, 0, 0, LR_LOADFROMFILE);if (hIcon){ // 设置窗口图…

Linux,Web网站服务(一)

1.准备工作 为了避免发生端口冲突&#xff0c;程序冲突等现象&#xff0c;建议卸载使用RPM方式安装的httpd [rootnode01 ~]# rpm -e http --nodeps 挂载光盘到/mnt目录 [rootnode01 ~]# mount /dev/cdrom /mnt Apache的配置及运行需要apr.pcre等软件包的支持&#xff0c;因此…

牛客网SQL训练2—SQL基础进阶

文章目录 一、基本查询二、数据过滤三&#xff1a;函数四&#xff1a;分组聚合五&#xff1a;子查询六&#xff1a;多表连接七&#xff1a;组合查询八&#xff1a;技能专项-case when使用九&#xff1a;多表连接-窗口函数十&#xff1a;技能专项-having子句十一&#xff1a;技能…

Web信息收集,互联网上的裸奔者

Web信息收集&#xff0c;互联网上的裸奔者 1.资产信息收集2.域名信息收集3.子域名收集4.单点初步信息收集网站指纹识别服务器类型(Linux/Windows)网站容器(Apache/Nginx/Tomcat/IIS)脚本类型(PHP/JSP/ASP/ASPX)数据库类型(MySQL/Oracle/Accees/SqlServer) 5.单点深入信息收集截…

Linux-----10、查找命令

# 查找命令 # 1、 命令查找 Linux下一切皆文件&#xff01; which 命令 &#xff1a;找出命令的绝对路径 whereis 命令 &#xff1a;找出命令的路径以及文档手册信息 [rootheima ~]# which mkdir /usr/bin/mkdir[rootheima ~]# whereis mkdir mkdir: /usr/bin/mkdir /usr/…

Py-While循环语句

while循环语句&#xff1a; 注意&#xff1a; while的条件需要得到布尔类型的结果&#xff0c;true继续循环&#xff0c;false退出循环需要设置循环终止的条件&#xff0c;不可以让程序一直无线循环运行下去空格缩进与if一样 语法格式:(只要条件满足会一直循环) while 布尔…

一款计算机顶会爬取解析系统 paper info

一款计算机顶会爬取解析系统 paper info 背景项目实现的功能 技术方案架构设计项目使用的技术选型 使用方法本地项目部署使用ChatGPT等大模型创建一个ChatGPT助手使用阿里云 顶会数据量 百度网盘pfd文件json文件 Q&A github链接 &#xff1a;https://github.com/codebricki…

Java面试题13

1.数据库的三范式是什么&#xff1f; 数据库的三范式是指数据库设计的一种规范&#xff0c;用来规定如何将数据进行组织和存储&#xff0c;以便减 少冗余、提高数据的一致性和准确性。具体来说&#xff0c;三范式分为三个层次&#xff1a; 第一范式&#xff08;1NF&#xff09…

(反序列化)小记录

目录 [CISCN 2023 华北]ez_date 绕过MD5和sha1强相关绕过 date()绕过 payload [FSCTF 2023]ez_php [CISCN 2023 华北]ez_date <?php error_reporting(0); highlight_file(__FILE__); class date{public $a;public $b;public $file;public function __wakeup(){if(is_a…

【快刊】Springer旗下2区,仅1个月左右录用,国人极其友好!

计算机类 • 好刊解读 今天小编带来Springer旗下计算机领域好刊&#xff0c;如您有投稿需求&#xff0c;可作为重点关注&#xff01;后文有相关领域真实发表案例&#xff0c;供您投稿参考~ 01 期刊简介 ✅出版社&#xff1a;Springer ✅影响因子&#xff1a;4.0-5.0 ✅期刊…

docker小白第三天

docker小白第三天 docker为什么会比虚拟机快 1、docker有着比虚拟机更少的抽象层。不需要Hypervisor实现硬件资源虚拟化&#xff0c;运行在docker容器上的程序直接使用的都是实际物理机的硬件资源&#xff0c;因此在CPU、内存利用率上docker将会在效率上有明显优势。 2、dock…

Vray批量云渲染怎么设置?Vray批量云渲染教程

V-Ray&#xff0c;作为业界知名的渲染引擎&#xff0c;其内置的Batch Render&#xff08;批处理渲染&#xff09;功能让艺术家和设计者们能够高效率地处理多场景或多视角的渲染任务。通过这一功能&#xff0c;用户可以设置一系列渲染队列&#xff0c;无需监督即可自动完成整个渲…

【期末向】“我也曾霸榜各类NLP任务”-bert详解

预训练语言模型 预训练语言模型于 2015 年被首次提出&#xff08;Dai & Le,2015&#xff09;。首先我们要了解一下什么是预训练模型&#xff0c;举个例子&#xff0c;假设我们有大量的维基百科数据&#xff0c;那么我们可以用这部分巨大的数据来训练一个泛化能力很强的模型…

C语言编程经典100例——21至30例

目录 第 21 例 第 22 例 第 23 例 第 24 例 第 25 例 第 26 例 第 27 例 第 28 例 第 29 例 第 30 例 第 21 例 程序源码&#xff1a; /* 题目&#xff1a;猴子吃桃问题&#xff1a;猴子第一天摘下若干个桃子&#xff0c;当即吃了一半&#xff0c;还不过瘾&#xf…

渗透测试框架——Cobalt Strike

渗透测试框架——Cobalt Strike Cobalt Strike是一款非常成熟的渗透测试框架。Cobalt Strike在3.0版本之前是基于Metasploit框架工作的&#xff0c;可以使用Metasploit的漏洞库。从3.0版本开始&#xff0c;Cobalt Strike不再使用Metasploit的漏洞库&#xff0c;成为一个独立的…