单调栈-java

本次主要通过数组模拟单调栈来解决问题。

目录

一、单调栈☀

二、算法思路☀

 1.暴力做法🌙

2.优化做法🌙

3.单调递增栈和单调递减栈🌙

三、代码如下☀

1.代码如下(示例):🌙

2.读入数据🌙

3.代码运行结果🌙

总结


前言

本次主要通过数组模拟单调栈来解决问题。


提示:以下是本篇文章正文内容,下面案例可供参考

一、单调栈☀

给定一个长度为 N 的整数数列,输出每个数左边第一个比它小的数,如果不存在则输出 −1。

输入格式

第一行包含整数 N,表示数列长度。

第二行包含 N个整数,表示整数数列。

输出格式

共一行,包含 N个整数,其中第 i个数表示第 i 个数的左边第一个比它小的数,如果不存在则输出 −1。

数据范围

1≤N≤100000
1≤数列中元素≤10^9

二、算法思路☀

我们引入一个整型数组arr来存储序列。

 1.暴力做法🌙

图1.1思路模拟 

我们要找寻数组中的每一个数的左边离它最小的数,如果找到就输出这个数;如果不存在的话就输出-1。那么我们就可以通过枚举数组中的每一个数,i表示数组中的第i个数。然后我们里面再写一层循环,用来枚举从数组第i-1个数到数组第1个数,用j来表示数组中第j个数。那么我们只需要来判断此时的数组第j个数是否小于第i个数即arr[j] < arr[i],如果小于的话,打印数组中的第j个数退出内循环,外循环接着进行下一层,依次类推。代码如下:

        for(int i = 1;i <= n;i++ ){for(int j = i - 1;j >= 1;j--){if (arr[j] < arr[i]){//找到了,退出内层循环pw.println(arr[j]);break;}}//不存在,输出-1pw.println(-1);}

可以看出我们的时间复杂度是O(n^2),整数N的范围是到10^5,这样肯定会超时。

2.优化做法🌙

我们引入一个一维整型数组stack用来模拟栈;一个整型变量top表示栈顶指针。

图2.1 栈中元素模拟

因为我们需要找到离它左边最近的第一个小于它的元素。我们将这个元素左边的全部元素放入栈中,比如我们需要找第i个元素a_{i}的左边第1个小于它的元素,那么如果a_{i-1} >= a_{i},那么a_{i-1}就肯定不可能作为最终的结果被输出,将a_{i-1}出栈。然后我们接着找a_{i-2},接着比较如果a_{i-2}\geqslant a _{i},再将a_{i-2}出栈,直到找到一个小于a_{i}的值,退出循环。

如果此时栈是空栈,就说明没有一个值是小于a_{i}的,打印-1;如果栈不是空栈,此时栈顶元素就是a_{i}的左边第一个小于它的值。

下面是样例3 4 2 7 5过程中栈中数据的模拟过程:

图2.2模拟一

图 2.3模拟二

图2.4模拟三 

图2.5模拟四

 图2.6模拟五

        for(int i = 0;i < n;i++){int x = sc.nextInt();//将x左边大于等于x的元素出栈while (top != -1 && stack[top] >= x){top--;}//栈不为空,此时栈顶元素就是x的左边第一个小于x的值if(top != -1){pw.print(stack[top]+" ");}//栈为空,说明x的左边不存在小于x的值else {pw.print(-1+" ");}//将x入栈stack[++top] = x;}

通过上述操作,我们每个元素最多入栈和出栈1次,最终的时间复杂度也就是O(n)。

3.单调递增栈和单调递减栈🌙


单调递增栈:在保持栈内元素单调递增的前提下(如果栈顶元素大于要入栈的元素,将将其弹出),将新元素入栈。

单调递减栈:在保持栈内元素单调递减的前提下(如果栈顶元素小于要入栈的元素,则将其弹出),将新元素入栈。

三、代码如下☀

1.代码如下(示例):🌙

import java.io.*;
import java.util.*;public class 单调栈 {static PrintWriter pw = new PrintWriter(new OutputStreamWriter(System.out));static BufferedReader br = new BufferedReader(new InputStreamReader(System.in));static int N = 100010;static int[] stack = new int[N];static int top = -1;public static void main(String[] args) {Scanner sc = new Scanner(br);int n = sc.nextInt();for(int i = 0;i < n;i++){int x = sc.nextInt();while (top != -1 && stack[top] >= x){top--;}if(top != -1){pw.print(stack[top]+" ");}else {pw.print(-1+" ");}stack[++top] = x;}pw.flush();}
}

2.读入数据🌙

5
3 4 2 7 5

3.代码运行结果🌙

-1 3 -1 2 2 

总结

单调栈问题大致就这一种类型问题,并不复杂,本次问题主要还是通过单调栈来优化时间复杂度来解决暴力做法超时问题。

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

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

相关文章

thinkphp5 配合阿里直播实现直播功能流程

要为你提供一个更详细的教程来结合ThinkPHP 5和阿里直播SDK实现直播功能&#xff0c;需要涵盖的内容相对较多。不过&#xff0c;我可以为你提供一个大致的、更详细的步骤指南&#xff0c;供你参考和扩展&#xff1a; 1. 准备工作 a. 注册阿里云账号 前往阿里云官网注册账号&…

Ubuntu MATE系统下WPS显示错位

系统&#xff1a;Ubuntu MATE 22.04和24.04&#xff0c;在显示器设置200%放大的情况下&#xff0c;显示错位。 显示器配置&#xff1a; WPS显示错位&#xff1a; 这个问题当前没有找到好的解决方式。 因为4K显示屏设置4K分辨率&#xff0c;图标&#xff0c;字体太小&#xff…

LeetCode题目100:递归、迭代、dfs使用栈多种算法图解相同的树

题目描述 给定两个二叉树的根节点 p 和 q&#xff0c;编写一个函数来检测这两棵树是否相同。如果两棵树在结构上相同&#xff0c;并且节点具有相同的值&#xff0c;则认为它们是相同的。 示例 示例 1 输入&#xff1a;p [1,2,3], q [1,2,3] 输出&#xff1a;True 示例 2…

PostgreSQL 数据库的备份和恢复

1. 备份数据库&#xff1a; a. 备份格式选择 *.bak&#xff1a;压缩二进制格式*.sql&#xff1a;明文转储*.tar&#xff1a;tarball b. 使用 pg_dump 命令备份数据库 使用 pg_dump 备份整个数据库&#xff1a; pg_dump -U 数据库角色 dbname > backup.sql pg_dump -U p…

prometheus搭建

1.prometheus下载 下载地址:Download | Prometheus 请下载LTS稳定版本 本次prometheus搭建使用prometheus-2.37.1.linux-amd64.tar.gz版本 2.上传prometheus-2.37.1.linux-amd64.tar.gz至服务器/opt目录 CentOS7.9 使用命令rz -byE上传 3.解压缩prometheus-2.37.1.linux…

前端面试题(二)

面试形式&#xff1a;线上面试&#xff08;不露脸&#xff09;&#xff1a;时长40分钟 面试评价&#xff1a;由易到难&#xff0c;由细到全&#xff0c;比较不错 面试官&#xff1a;项目经理 面试官提问&#xff08;面试题&#xff09;&#xff1a; 1、聊聊最近写的这个项目…

【C++之map的应用】

C学习笔记---021 C之map的应用1、map的简单介绍1.1、基本概念1.2、map基本特性 2、map的基本操作2.1、插入元素2.2、访问元素2.3、删除元素2.4、遍历map2.5、检查元素是否存在2.6、获取map的大小2.7、清空map2.8、基本样例 3、map的基础模拟实现4、测试用例4.1、插入和遍历4.2、…

Flutter笔记:Widgets Easier组件库(11)- 使用提示吐丝

Flutter笔记 Widgets Easier组件库&#xff08;11&#xff09;使用提示吐丝 - 文章信息 - Author: 李俊才 (jcLee95) Visit me at CSDN: https://jclee95.blog.csdn.netMy WebSite&#xff1a;http://thispage.tech/Email: 291148484163.com. Shenzhen ChinaAddress of this …

【多模态】29、OCRBench | 为大型多模态模型提供一个 OCR 任务测评基准

文章目录 一、背景二、实验2.1 测评标准和结果2.1.1 文本识别 Text Recognition2.1.2 场景文本中心的视觉问答 Scene Text-Centric VQA2.1.3 文档导向的视觉问答 Document-Oriented VQA2.1.4 关键信息提取 Key Information Extraction2.1.5 手写数学公式识别 Handwritten Mathe…

.LockBit 3.0勒索病毒解密方法|勒索病毒解决|勒索病毒恢复|数据库修复

尊敬的读者&#xff1a; 网络安全是现代社会的重要基石&#xff0c;但勒索病毒等网络威胁却不断挑战着我们的防线。.LockBit 3.0作为近期出现的新型勒索病毒&#xff0c;其独特的攻击方式和强大的加密能力引起了广泛关注。本文将深入解析.LockBit 3.0的特点&#xff0c;并给出…

Ubuntu安装配置网络

参考 https://blog.csdn.net/qq_59633155/article/details/131252293https://blog.csdn.net/qq_59633155/article/details/131252293 Ubuntu配置网络 1&#xff0c;查看网络是否连接 终端输入 ping baidu.com 如若成功则如下图所示 如未能成功&#xff0c;则继续按下面步骤…

解决HTTP 403 Forbidden错误:禁止访问目录索引问题的解决方法

解决HTTP 403 Forbidden错误&#xff1a;禁止访问目录索引问题的解决方法 过去有人曾对我说&#xff0c;“一个人爱上小溪&#xff0c;是因为没有见过大海。”而如今我终于可以说&#xff0c;“我已见过银河&#xff0c;但我仍只爱你一颗星。” 在Web开发和服务器管理中&#x…

npm 使用总结

npm&#xff08;Node Package Manager&#xff09;是Node.js的包管理器&#xff0c;它允许你安装、更新、删除和管理Node.js应用程序的依赖项。以下是npm的一些使用总结&#xff1a; 安装npm&#xff1a;npm通常与Node.js一起安装。你可以从Node.js的官方网站下载适合你操作系统…

【精品毕设推荐】基于JSP物流信息网的设计与实现

点击免费下载原文及代码、PPT 摘要 本文讲述了基于JSP物流信息网的设计与实现。该系统使用java语言开发&#xff0c;使系统具有更好的平台性和可扩展性。 该系统实现了用户登录、注册、查询快递信息、快递公司注册成为合作伙伴以及系统管理员对信息进行管理等功能。系统的主…

(三)JVM实战——对象的内存布局与执行引擎详解

对象的内存布局 对象的实例化 对象的创建方式 - new的方式 - Class的newInstance():反射的方式 - Construct的newInstance() - clone:实现Cloneable接口,默认浅拷贝 - 使用反序列化&#xff1a;将二进制流转化为内存对象 创建对象的步骤 - 判断对象对应的类是否加载、链接、初…

You don’t have permission.

The document “XXX” could not be saved. You don’t have permission. 1.查看修改了iOS系统库导致的, 根据提示, 进入到"XXX"文件中, 然后commandz回退/取消 2. Xcode 调试遇到的报错&#xff08;持续更新&#xff09;

基于频率比模型采用arcgis的滑坡易发性评估

目录 参考视频:频率比模型地形因子处理shp文件与缓冲区地理校准填补缺失值利用模糊隶属度进行归一化易发性结果出图处理:参考视频: 1. ArcGIS滑坡易发性评价_哔哩哔哩_bilibili 2. landslides susceptibility assessemnt using frequently ration approach /滑坡敏感性制图…

四工位自动攻丝机自动控制

/**************进料检测********************/ /***缺料无限次循环 手动退出 超时报警*******/ void check_Pon() { zstatus0; //缺料报警计数器归零 Signauto1; //…

android native开发

framwork 一些重要的流程都是要放到native中做的 原因也很简单&#xff0c;效率&#xff0c;尤其是针对性能优化方面的&#xff0c;更离不开native开发 目前针对native开发也回顾下&#xff0c;总结下经验 1 jni开发有两种&#xff0c;app端一般是静态模式&#xff0c;要有jav…

18_Scala面向对象编程trait

文章目录 trait1.定义trait2.向类中混入特质2.1没有父类2.2有父类 3.动态混入3.1动态混入查询功能到公司业务中 4.父类&#xff0c;子类&#xff0c;特质初始化优先级5.Scala功能执行顺序6.常用API trait –特质的学习需要类比Java中的接口&#xff0c;源码编译之后就是interf…