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

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

运行结果:

相关推荐
墨尘笔尖15 小时前
最大最小值降采样算法的优化
c++·算法
自我意识的多元宇宙16 小时前
二叉树的遍历和线索二叉树--二叉树的遍历
数据结构
qq_50242899016 小时前
清华大学与微软亚洲研究院出品:Kronos 本地部署教程
数据结构·python·金融量化·kronos开源模型
white-persist17 小时前
【vulhub shiro 漏洞复现】vulhub shiro CVE-2016-4437 Shiro反序列化漏洞复现详细分析解释
运维·服务器·网络·python·算法·安全·web安全
FL162386312917 小时前
基于C#winform部署软前景分割DAViD算法的onnx模型实现前景分割
开发语言·算法·c#
baizhigangqw18 小时前
启发式算法WebApp实验室:从搜索策略到群体智能的能力进阶
算法·启发式算法·web app
C雨后彩虹18 小时前
最多等和不相交连续子序列
java·数据结构·算法·华为·面试
cpp_250119 小时前
P2347 [NOIP 1996 提高组] 砝码称重
数据结构·c++·算法·题解·洛谷·noip·背包dp
Hugh-Yu-13012319 小时前
二元一次方程组求解器c++代码
开发语言·c++·算法
编程大师哥20 小时前
C++类和对象
开发语言·c++·算法