2025年--Lc298-1019. 链表中的下一个更大节点(栈)--java版

1.题目

2.思路

(1)栈中存的元素:每个元素是 int[]{节点值, 节点下标},比如 {2, 0} 表示:

这个节点的值 = 2

它在结果数组中的位置 = 0

new int[]{cur.val, cnt}

··············

res 是"答案列表",按链表顺序存每个节点的【下一个更大节点的值】。

先假设它没有更大值,预填 0

(2)从栈底到栈顶,节点值是单调递减的。

遍历到一个新节点 cur 时,如果 cur.val 比栈顶的小或相等,那它也"没有更大值",先压栈。

一旦 cur.val 比栈顶的大,就说明:

对栈顶那个节点来说,当前的 cur.val 就是它"后面第一个更大的值",

那就把栈顶弹出,同时在结果数组对应位置写上 cur.val。

(3)遍历完链表后:

栈里剩下的节点就说明后面再也没更大的了,

你之前已经 res.add(0) 预填了 0,直接保留就行。



3.代码实现

java 复制代码
/**
 * Definition for singly-linked list.
 * public class ListNode {
 *     int val;
 *     ListNode next;
 *     ListNode() {}
 *     ListNode(int val) { this.val = val; }
 *     ListNode(int val, ListNode next) { this.val = val; this.next = next; }
 * }
 */
class Solution {
    public int[] nextLargerNodes(ListNode head) {
        List<Integer> res=new ArrayList<>();
        Deque<int[]> st=new ArrayDeque<int[]>();
        ListNode cur=head;
        int cnt=-1;
        while(cur!=null)
        {
            cnt++;
            res.add(0);//如果没找到比当前元素更大的元素返回0
            //当栈不空,且取出栈顶数组的第一个元素
            while(!st.isEmpty()&&st.peek()[0]<cur.val)
            {
                res.set(st.pop()[1],cur.val);
            }
            st.push(new int[]{cur.val,cnt});
            cur=cur.next;
        }
        //将列表转换成数组
        int size=res.size();
        int[] arr=new int[size];
        for(int i=0;i<size;i++)
        {
            arr[i]=res.get(i);
        }
        return arr;
        
    }
}
相关推荐
野犬寒鸦2 分钟前
JVM垃圾回收机制深度解析(G1篇)(垃圾回收过程及专业名词详解)(补充)
java·服务器·开发语言·jvm·后端·面试
白宇横流学长2 分钟前
基于SpringBoot实现的信息技术知识赛系统设计与实现【源码+文档】
java·spring boot·后端
历程里程碑9 分钟前
44. TCP -23Linux聊天室实现命令符功能
java·linux·开发语言·数据结构·c++·排序算法·tcp
丶小鱼丶11 分钟前
数据结构和算法之【二叉树】
java·数据结构·算法
SimonKing13 分钟前
OpenClaw,再见!
java·后端·程序员
softbangong14 分钟前
829-批量提取各子文件夹下文件到一级目录
java·服务器·前端·自动化工具·批量文件处理·文件提取工具·文件夹整理
魑-魅-魍-魉17 分钟前
Maven 构建报错:无法连接私有仓库及依赖传输失败
java·maven
Thomas.Sir17 分钟前
精通 MySQL 面试题
数据结构·数据库·mysql
小王不爱笑13219 分钟前
Java 泛型详解
java·windows·python
罗湖老棍子24 分钟前
打鼹鼠_二维树状数组(信息学奥赛一本通- P1540)(二维树状数组模版题)
数据结构·算法·树状数组·二维树状数组