单调栈经典例题

java 复制代码
import java.util.Scanner;

public class Main{
    public static void main(String[] args) {
        //单调递增栈,栈中的所有元素严格单调递增
        //比如1 6 5 4 9 8 7 10 11 56不会出现在答案里
        //因为被4给拦截住了
        //遍历到4的时候可以把56都出栈
        //89也不会出现,被7拦住了
        //遍历到7的时候可以把89出栈
        Scanner sc = new Scanner(System.in);
        int n = sc.nextInt();

        int[] stack = new int[100010];
        int tt = 0;
        for (int i = 0; i < n; i++) {
            int x = sc.nextInt();
            //栈顶元素>=当前遍历到的元素就得出栈,出栈的元素以后都不会出现在答案里
            while (tt != 0 && stack[tt] >= x){
                tt--;
            }
            //退出循环时的栈顶就是要输出的结果
            if (tt != 0) System.out.print(stack[tt] + " ");
            else System.out.print("-1 ");

            //最后把该数放进栈里
            stack[++tt] = x;
        }
    }
}
相关推荐
兰令水几秒前
leecodecode【单调栈】【2026.6.12打卡-java版本】
java·开发语言·算法
leagsoft_10033 分钟前
零信任选型五刀法——零信任怎么选?五个问题,五条红线
开发语言·php
云烟成雨TD6 分钟前
Agent Scope Java 2.x 系列【8】工具调用
java·人工智能·agent
TMT星球10 分钟前
魔法原子上交会首秀VLA K02大模型,完成具身智能从“执行”到“理解”的能力跃迁
人工智能·算法·机器学习
2301_7644413312 分钟前
番茄钟+AI:高效专注的秘密武器
人工智能·算法·数学建模·动态规划·交互
AI人工智能+电脑小能手14 分钟前
【大白话说Java面试题 第112题】【并发篇】第12题:AQS 中节点的入队时机有哪些?
java·开发语言·面试
摇滚侠14 分钟前
SpringMVC 入门到实战 处理静态资源的过程 64
java·后端·spring·maven·intellij-idea
影寂ldy15 分钟前
C# 泛型委托
java·算法·c#
摇滚侠16 分钟前
MyBatis 入门到项目实战 MyBatis 核心配置文件 15-19
java·tomcat·mybatis
IT WorryFree16 分钟前
Zabbix 7.4 API 可同步全量参数清单(同步第三方系统专用)
java·开发语言·zabbix