leetcode503. 下一个更大元素 II 单调栈

思路:

与之前 739、1475 单调栈的问题如出一辙,唯一不同的地方就是对于遍历完之后。栈中元素的处理,之前的栈中元素因无法找到符合条件的值,直接加入vector中。而这里需要再重头遍历一下数组,找是否有符合条件的,如果仍然找不到的话,才会把它赋值然后加入vector中。

代码:

cpp 复制代码
class Solution {
public:
    vector<int> nextGreaterElements(vector<int>& nums) {
        int n = nums.size();
        vector<int> ans(n);
        stack<int> st;
        for (int i = 0; i < n; i++) {
            int t = nums[i];
            // 出栈并计算
            while (!st.empty() && t > nums[st.top()]) {
                int x = st.top();
                ans[x] = t;
                st.pop();
            }
            // 入栈
            while (st.empty() || (t <= nums[st.top()] && i != st.top())) {
                st.push(i);
            }
        }
        // 处理遍历完之后,栈中剩余的元素。
        while (!st.empty()) {
            int x = st.top();
            // 从头遍历数组看是否有符合要求的值。
            int i = 0;
            for (i = 0; i < n; i++) {
                if (nums[i] > nums[x]) {
                    ans[x] = nums[i];
                    break;
                }
            }
            if (i == n) ans[x] = -1;
            st.pop();
        }
        return ans;
    }
};

注意点:

for循环中的入栈出栈顺序非常重要!!!

出栈放在最后,则新元素无法入栈。

运行结果:

相关推荐
浅念-2 小时前
从LeetCode入门位运算:常见技巧与实战题目全解析
数据结构·数据库·c++·笔记·算法·leetcode·牛客
CoovallyAIHub2 小时前
无人机拍叶片→AI找缺陷:CEA-DETR改进RT-DETR做风电叶片表面缺陷检测,mAP50达89.4%
算法·架构·github
田梓燊2 小时前
leetcode 142
android·java·leetcode
CoovallyAIHub2 小时前
混合训练反而更差?VLM Agent在训练前协调跨数据集标注,文档布局检测F-score从0.860提升至0.883
算法·架构·github
鸿途优学-UU教育2 小时前
教材质量——法考培训的根基与底气
算法
_深海凉_2 小时前
LeetCode热题100-最大数(179)
算法·leetcode·职场和发展
剑挑星河月2 小时前
763.划分字母区间
数据结构·算法·leetcode
小辉同志3 小时前
74. 搜索二维矩阵
c++·leetcode·矩阵·二分查找
programhelp_3 小时前
Snowflake OA 2026 面经|3道高频真题拆解 + 速通攻略
经验分享·算法·面试·职场和发展
圣保罗的大教堂3 小时前
leetcode 3740. 三个相等元素之间的最小距离 I 简单
leetcode