LeetCode 1019.链表中的下一个更大节点

给定一个长度为 n 的链表 head

对于列表中的每个节点,查找下一个 更大节点 的值。也就是说,对于每个节点,找到它旁边的第一个节点的值,这个节点的值 严格大于 它的值。

返回一个整数数组 answer ,其中 answer[i] 是第 i 个节点( 从1开始 )的下一个更大的节点的值。如果第 i 个节点没有下一个更大的节点,设置 answer[i] = 0 。

示例 1:

输入:head = [2,1,5]

输出:[5,5,0]

示例 2:

输入:head = [2,7,4,3,5]

输出:[7,0,5,5,0]

提示:

链表中节点数为 n

1 <= n <= 104^44

1 <= Node.val <= 109^99

将链表转换为数组,然后使用单调栈即可:

cpp 复制代码
/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     ListNode *next;
 *     ListNode() : val(0), next(nullptr) {}
 *     ListNode(int x) : val(x), next(nullptr) {}
 *     ListNode(int x, ListNode *next) : val(x), next(next) {}
 * };
 */
class Solution {
public:
    vector<int> nextLargerNodes(ListNode* head) {
        vector<int> ans;
        ListNode *node = head;
        while (node) {
            ans.push_back(node->val);
            node = node->next;
        }

        stack<int> stk;
        for (int i = ans.size() - 1; i >= 0; --i) {
            while (!stk.empty() && ans[i] >= stk.top()) {
                stk.pop();
            }

            int curValue = ans[i];

            if (!stk.empty()) {
                ans[i] = stk.top();
            } else {
                ans[i] = 0;
            }

            stk.push(curValue);
        }

        return ans;
    }
};

如果链表长度为n,则此算法时间复杂度为O(n),空间复杂度为O(n)。

相关推荐
凌波粒5 小时前
LeetCode--404.左叶子之和(二叉树)
算法·leetcode·职场和发展
paeamecium6 小时前
【PAT甲级真题】- A+B in Hogwarts
c++·算法·pat考试·pat
青山师6 小时前
二叉树与BST深度解析:遍历算法与平衡策略
数据结构·算法·面试·二叉树·算法与数据结构·java面试·数据结构与算法分析
绝知此事6 小时前
【算法突围 03】核心算法思想:分治/递归/动态规划与 LeetCode 高频真题解析
算法·leetcode·面试·动态规划
AI科技星6 小时前
第二章 平行素数对网格:矩形→等腰梯形拓扑变换(完整公理终稿)
c语言·开发语言·线性代数·算法·量子计算·agi
宇明一不急6 小时前
go 链表 (标准库实现)
开发语言·链表·golang
AI视觉网奇6 小时前
blender bpy对齐物体
算法
吃好睡好便好6 小时前
在Matlab中绘制阶梯图
开发语言·人工智能·学习·算法·机器学习·matlab