456. 132 模式

news2024/11/27 2:18:04

456. 132 模式

  • 原题链接:
  • 完成情况:
  • 解题思路:
  • 参考代码:
    • 单调栈

原题链接:

456. 132 模式

https://leetcode.cn/problems/132-pattern/description/

完成情况:

在这里插入图片描述

解题思路:

	/**
	 解题思路:
	    i<j<k
	 arr[i]<arr[k]<arr[j]
	 这个得自己动一下脑子,可以推算出,从k开始找arr[i]、arr[j]效果会更好。      ->则我们应该从数组尾部开始遍历

	 优化:即两个元素,通过一个判断去移动,降低为O(n^2)
	 如上,我们先去找j出来,即arr[j]大于arr[k]的。
	    这是会有如下情况,接下来的元素:
	        1.比arr[k]小
	            return ture;
	        2.比arr[k]大,但比arr[j]小        我们管这个叫arr[temp]    temp<j
	            不用管
	        3.比arr[j]大       我们管这个叫arr[temp]    temp<j
	            我们使arr[k] = arr[j]
	            arr[j]  = arr[temp]
	 */

参考代码:

package 西湖算法题解___中等题;

import java.util.ArrayDeque;
import java.util.Deque;
import java.util.Stack;

public class __454是否有132模式__单调栈 {
	public boolean find132pattern(int[] nums) {
		/**
		 解题思路:
		    i<j<k
		 arr[i]<arr[k]<arr[j]
		 这个得自己动一下脑子,可以推算出,从k开始找arr[i]、arr[j]效果会更好。      ->则我们应该从数组尾部开始遍历

		 优化:即两个元素,通过一个判断去移动,降低为O(n^2)
		 如上,我们先去找j出来,即arr[j]大于arr[k]的。
		    这是会有如下情况,接下来的元素:
		        1.比arr[k]小
		            return ture;
		        2.比arr[k]大,但比arr[j]小        我们管这个叫arr[temp]    temp<j
		            不用管
		        3.比arr[j]大       我们管这个叫arr[temp]    temp<j
		            我们使arr[k] = arr[j]
		            arr[j]  = arr[temp]
		 */
		int nLength = nums.length;
		if (nLength < 3){
			return false;
		}
		Deque<Integer> stack = new ArrayDeque<Integer>();
		int temp = Integer.MIN_VALUE;
		for (int i = nLength-1;i>=0;i--){
			if (nums[i] < temp){
				return true;
			}
			while (!stack.isEmpty() && nums[i] > stack.peek()){
				temp = stack.pop();
			}
			stack.push(nums[i]);
		}
		return false;
	}
}

单调栈

单调栈(Monotonic Stack),也叫做单调递增栈或单调递减栈,是一种特殊类型的栈数据结构。它主要用于解决一些与序列中元素的单调性有关的问题,如寻找下一个更大的元素、寻找前一个更大的元素等。

单调栈的特点在于,栈中的元素保持特定的单调性(递增或递减)。当新的元素要入栈时,会先将栈中所有不满足单调性要求的元素出栈,然后再将新元素入栈。这样可以保证栈内元素始终保持单调性,从而能够在栈中高效地找到某些与单调性相关的信息。

常见的应用场景包括:

  1. 寻找下一个更大(或更小)元素:对于一个序列中的每个元素,需要找到在该元素右边第一个比它更大(或更小)的元素。单调栈可以帮助高效地解决这类问题。

  2. 柱状图中的最大矩形面积:给定一个柱状图,找到可以画出的最大矩形的面积。这个问题可以通过单调递增栈来解决。

  3. 滑动窗口的最大值:给定一个数组和一个固定大小的窗口,窗口从数组的最左边滑动到最右边,需要找到每个窗口中的最大值。

  4. 删除数组中的元素以获得单调数组:给定一个数组,通过删除一些元素,使得剩余元素形成一个单调递增或单调递减的数组。

等等。

单调栈的思想在解决这些问题时能够以较低的时间复杂度实现,因为它可以避免重复计算,只保留有用的信息。无论是单调递增栈还是单调递减栈,其基本操作都是入栈和出栈,通过这些操作来维护单调性,从而解决各种相关问题。

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

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

相关文章

内网搭建电影网站的实现和进行公网访问

如何实现内网搭建电影网站并进行公网访问 文章目录 如何实现内网搭建电影网站并进行公网访问前言1. 把软件分别安装到本地电脑上1.1 打开PHPStudy软件&#xff0c;安装一系列电影网站所需的支持软件1.2 设置MacCNS10的运行环境1.3 进入电影网页的安装程序1.4 对运行环境进行检测…

VSCode如何设置高亮

一、概述 本文主要介绍在 VSCode 看代码时&#xff0c;怎样使某个单词高亮显示&#xff0c;主要通过以下三步实现&#xff1a; 安装 highlight-words 插件 配置 highlight-words 插件 设置高亮快捷键F8 工作是嵌入式开发的&#xff0c;代码主要是C/C的&#xff0c;之前一直用…

通过网关访问微服务,一次正常,一次不正常 (nacos配置的永久实例却未启动导致)

微服务直接访问没问题&#xff0c;通过网关访问&#xff0c;就一次正常访问&#xff0c;一次401错误&#xff0c;交替正常和出错 负载均衡试了 路由配置检查了 最后发现nacos下竟然有2个order服务实例&#xff0c;我明明只开启了一个呀 原来之前的8080端口微服务还残留&…

PyQt5控件布局管理

Qt Designer提供了四种窗口布局&#xff1a;Vertical Layout(垂直布局) &#xff0c;Horizontal Layout(水平布局)&#xff0c;Grid Layout(栅格布局)&#xff0c;Form Layout(表单布局)&#xff0c;以及一种隐藏的布局—绝对布局 一般进行布局有两种方式&#xff1a; 一是通…

二次封装element-plus上传组件,提供校验、回显等功能

二次封装element-plus上传组件 0 相关介绍1 效果展示2 组件主体3 视频组件4 Demo 0 相关介绍 基于element-plus框架&#xff0c;视频播放器使用西瓜视频播放器组件 相关能力 提供图片、音频、视频的预览功能提供是否为空、文件类型、文件大小、文件数量、图片宽高校验提供图片…

Github标星98k,企业级Spring Boot项目开发实战笔记,太强了

准备又到了一年一度的金九银十招聘高峰期的时间&#xff0c;虽然这两年因为疫情以及经济环境不太好&#xff0c;互联网行业的各大厂都再裁员&#xff0c;但是今年下半年Java行情在慢慢的复苏&#xff0c;在慢慢的变好。 随着上半年病态卷的常态在慢慢的退去&#xff0c;互联网…

【Java】2021 RoboCom 机器人开发者大赛-高职组(初赛)题解

7-1 机器人打招呼 机器人小白要来 RoboCom 参赛了&#xff0c;在赛场中遇到人要打个招呼。请你帮它设置好打招呼的这句话&#xff1a;“ni ye lai can jia RoboCom a?”。 输入格式&#xff1a; 本题没有输入。 输出格式&#xff1a; 在一行中输出 ni ye lai can jia Robo…

【Linux】简单线程池的设计与实现 -- 单例模式

前言对锁的封装整体代码LockGuard - RALLRALLMutex封装 对线程创建的封装整体代码成员函数解释声明 业务处理封装-加减乘除&#xff08;可有可无&#xff09;整体代码成员函数解释声明 线程池的设计与实现整体代码成员函数解释声明 展示 前言 线程池: 一种线程使用模式。线程过…

Mybatis 源码 ∞ :杂七杂八

文章目录 一、前言二、TypeHandler三、KeyGenerator四、Plugin1 Interceptor2 org.apache.ibatis.plugin.Plugin3. 调用场景 五、Mybatis 嵌套映射 BUG1. 示例2. 原因3. 解决方案 六、discriminator 标签七、其他1. RowBounds2. ResultHandler3. MapKey 一、前言 Mybatis 官网…

无涯教程-Perl - seekdir函数

描述 此功能将DIRHANDLE中的当前位置设置为POS。 POS的值必须是Telldir先前返回的值。 seekdir()函数类似于Unix seekdir()系统调用。 语法 以下是此函数的简单语法- seekdir DIRHANDLE, POS返回值 如果失败,此函数返回0,如果成功,则返回1。 例 以下是显示其基本用法的…

VMware Workstation 如何启用复制粘贴

产品&#xff1a;VMware Workstation 16 Pro 版本&#xff1a;16.1.1 build-17801498 我们刚安装好的 VMware Workstation 会发现无法复制粘贴文件到虚拟机中&#xff0c;如下为解决方案&#xff1a; 1.点击 虚拟机&#xff0c;点击 安装 VMware Tools(T)...。 2.虚拟机下面会…

从零实战SLAM-第五课(最小二乘法)

在七月算法报的班&#xff0c;老师讲的蛮好。好记性不如烂笔头&#xff0c;关键内容还是记录一下吧&#xff0c;课程入口&#xff0c;感兴趣的同学可以学习一下。 --------------------------------------------------------------------------------------------------------…

Windows 搜索指定软件启动路径

Windows 搜索指定软件启动路径 通过指定软件名称&#xff0c;使用命令搜索软件安装路径 # 示例&#xff1a;搜索“钉钉”的启动路径 echo off rem 指定待搜索的文件 set "FileNameDingTalk.exe" rem echo 正在搜索&#xff0c;请稍候... for %%a in (C D E F G H I J…

javaswing人事管理系统企业员工工资管理mysql数据库MVC三层框架gui源代码

本项目为前几天收费帮学妹做的一个项目&#xff0c;Java EE JSP项目&#xff0c;在工作环境中基本使用不到&#xff0c;但是很多学校把这个当作编程入门的项目来做&#xff0c;故分享出本项目供初学者参考。 一、主要功能 人事管理&#xff1a;添加员工、工资管理、部门管理 …

sykwalking8.2和mysql5.7快速部署

1.SkyWalking 是什么&#xff1f; 分布式系统的应用程序性能监视工具&#xff0c;专为微服务、云原生架构和基于容器&#xff08;Docker、K8s、Mesos&#xff09;架构而设计。 提供分布式追踪、服务网格遥测分析、度量聚合和可视化一体化解决方案。 2.SkyWalking 有哪些功能…

考公-判断推理-定义判断

第九节课 例题 例题 例题 例题 例题 例题 脚一滑&#xff0c;就是工伤&#xff0c;这难道不是操作不当吗 例题 不要较真&#xff0c;公务员&#xff0c;把没有全局观念的人排除在公务员队伍之外 例题 例题 下次看到不字&#xff0c;先给我画上 例题 例题 例题 例题…

Scratch 之 3D 画笔程序使用

目录 Part1 摄像头固定的3D效果 Part2 尝试移动摄像头 Part3 边缘裁剪 总结&#xff1a; Part1 摄像头固定的3D效果 首先&#xff0c;我们知道sc中有xy坐标。 现在让我们在sc中引入一个新坐标——z坐标。z轴垂直于电脑屏幕&#xff0c;从屏幕外指向屏幕里。(如下图) z坐标…

O2OA (翱途) o2server 调用 webServices jaxws 样例

本文分两部分介绍如何在 o2server 服务器中调用 webServices(jaxws)服务. 第一部分介绍如何在tomcat上搭建一个webServices(jaxws)服务. 第二部分介绍如何在o2server服务器上来调用上面创建的服务. O2OA (翱途)官网&#xff1a;http://www.o2oa.net 一、在tomcat上搭建一个…

Redis辅助功能

一、Redis队列 1.1、订阅 subscribe ch1 ch2 1.2 publish:发布消息 publish channel message 1.3 unsubscribe: 退订 channel 1.4 模式匹配 psubscribe ch* 模糊发布&#xff0c;订阅&#xff0c;退订&#xff0c; p* <channelName> 1.5 发布订阅原理 订阅某个频道或…

【正点原子STM32连载】第五章 APM32基础知识入门摘自【正点原子】APM32F407最小系统板使用指南

1&#xff09;实验平台&#xff1a;正点原子stm32f103战舰开发板V4 2&#xff09;平台购买地址&#xff1a;https://detail.tmall.com/item.htm?id609294757420 3&#xff09;全套实验源码手册视频下载地址&#xff1a; http://www.openedv.com/thread-340252-1-1.html# 第五…