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循环中的入栈出栈顺序非常重要!!!

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

运行结果:

相关推荐
锅挤11 分钟前
数据结构复习(第五章):树与二叉树
数据结构
小章UPUP14 分钟前
2026年第十六届MathorCup数学应用挑战赛D题国奖思路
算法
hssfscv21 分钟前
软件设计师下午试题四——C语言(N皇后问题、分治、动态规划)
c语言·算法·动态规划
lolo大魔王31 分钟前
Go语言的反射机制
开发语言·后端·算法·golang
白羊by43 分钟前
Softmax 激活函数详解:从数学原理到应用场景
网络·人工智能·深度学习·算法·损失函数
杨凯凡1 小时前
【014】基本类型与包装类:缓存、相等性、NPE
java·数据结构·缓存
故事和你911 小时前
洛谷-算法1-7-搜索3
数据结构·c++·算法·leetcode·动态规划
chipsense1 小时前
霍尔电流传感器选型方法论再升级:从800V平台到TMR竞争的全场景决策树
算法·决策树·机器学习·闭环霍尔·tmr传感
CoderYanger1 小时前
14届蓝桥杯省赛Java A 组Q1~Q3
java·开发语言·线性代数·算法·职场和发展·蓝桥杯
想唱rap2 小时前
C++智能指针
linux·jvm·数据结构·c++·mysql·ubuntu·bash