leetcode 栈有关的模板题

739 每日温度

https://leetcode-cn.com/problems/daily-temperatures/

题目描述:
在这里插入图片描述
具体思路:
从数组最后开始入栈,如果当前元素比栈顶元素还大,说明当前元素所表示的温度比之后的栈顶元素还要大,在当前元素前面的元素对应的温度找更大温度时,一定不会是栈顶元素了,栈顶元素直接弹出。while循环之后栈空,说明当前元素所代表的温度是后面最大的。最后别忘了当前元素对应下标入栈。

class Solution {
public:
    vector<int> dailyTemperatures(vector<int>& temperatures) {
        int n=temperatures.size();
        stack<int> st;
        vector<int> ans(n,0);
        for(int i=n-1;i>=0;i--)
        {
            int num=temperatures[i];
            while(!st.empty()&&num>=temperatures[st.top()])
            {
                st.pop();
                
            }
            ans[i]=st.empty()?0:st.top()-i;
            st.push(i);
        }
        return ans;
     }
};

503 下一个更大元素II

https://leetcode-cn.com/problems/next-greater-element-ii/
在这里插入图片描述
思路分析:考虑组成一个长度为2*n-1的数组代替环形数组的思路。

class Solution {
public:
    vector<int> nextGreaterElements(vector<int>& nums) {
        stack<int> st;
        int n=nums.size();
        vector<int> ans(n,0);
        for(int i=2*n-1;i>=0;i--)
        {
            int num=nums[i%n];
            while(!st.empty()&&num>=st.top())
                st.pop();
            ans[i%n]=st.empty()?-1:st.top();
            st.push(num);
        }
        return ans;
    }
};

496 下一个更大元素I

https://leetcode-cn.com/problems/next-greater-element-i/
在这里插入图片描述
这居然是简单题!unordered_map太厉害了!

class Solution {
public:
    vector<int> nextGreaterElement(vector<int>& nums1, vector<int>& nums2) {
        unordered_map <int,int> hashmap;
        stack<int> st;
        for(int i=nums2.size()-1;i>=0;i--)
          {
              int num=nums2[i];
              while(!st.empty()&&num>=st.top())
              st.pop();
              hashmap[num]=st.empty()?-1:st.top();
              st.push(num);
          }
        vector<int>res (nums1.size());
        for(int i=0;i<nums1.size();i++)
        res[i]=hashmap[nums1[i]];
        return res;

    }
};

456.132模式

https://leetcode-cn.com/problems/132-pattern/
具体思路参考评论区三叶。
在这里插入图片描述k代表出栈元素的最大值,初始化为INT_MIN。
这种做法一定能得到nums[j]最大的一个子序列。

class Solution {
public:
    bool find132pattern(vector<int>& nums) {
        stack<int> st;
        int k=INT_MIN;
        for(int i=nums.size()-1;i>=0;i--)
        {
            if(nums[i]<k) return true;
            while(!st.empty()&&nums[i]>st.top())//这个地方不可以为>=,因为k从INT_MIN变成有效值的理由必须是前面有大的数
            {
               k=max(st.top(),k);
               st.pop();               
            }
        st.push(nums[i]);
        }
     return false;
    }
};
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
1. 二分法 5 1.1. 什么是二分查找 5 1.2. 如何识别二分法 5 1.3. 二分法模板 6 1.3.1. 模板一 6 1.3.1.1. 模板代码 6 1.3.1.2. 关键属性 7 1.3.1.3. 语法说明 7 1.3.1.4. Lc69:x的平方根 8 1.3.1.5. Lc374:猜数大小 9 1.3.1.6. Lc33:搜索旋转数组 11 1.3.2. 模板二 13 1.3.2.1. 模板代码 13 1.3.2.2. 关键属性 14 1.3.2.3. 语法说明 14 1.3.2.4. Lc278:第一个错误版本 14 1.3.2.5. Lc162:寻找峰值 16 1.3.2.6. Lc153:寻找旋转排序数组最小值 19 1.3.2.7. Lc154:寻找旋转排序数组最小值II 20 1.3.3. 模板三 22 1.3.3.1. 模板代码 22 1.3.3.2. 关键属性 23 1.3.3.3. 语法说明 23 1.3.3.4. LC-34:在排序数组中查找元素的第一个和最后一个 23 1.3.3.5. LC-658:找到K个最接近的元素 25 1.3.4. 小结 28 1.4. LeetCode中二分查找目 29 2. 双指针 30 2.1. 快慢指针 31 2.1.1. 什么是快慢指针 31 2.1.2. 快慢指针模板 31 2.1.3. 快慢指针相关目 32 2.1.3.1. LC-141:链表是否有环 32 2.1.3.2. LC-142:环形链表入口 34 2.1.3.3. LC-876:链表的中间节点 37 2.1.3.4. LC-287:寻找重复数 40 2.2. 滑动窗口 43 2.2.1. 什么是滑动窗口 43 2.1.4. 常见型 44 2.1.5. 注意事项 45 2.1.6. 滑动窗口模板 45 2.1.7. 滑动窗口相关目 46 2.1.7.1. LC-3:无重复字符的最长子串 47 2.1.7.2. LC-76:最小覆盖子串 49 2.1.7.3. LC-209:长度最小的子数组 54 2.1.7.4. LC-239:滑动窗口最大值 57 2.1.7.5. LC-395:至少有K个重复字符的最长子串 60 2.1.7.6. LC-567:字符串排列 62 2.1.7.7. LC-904:水果成篮 64 2.1.7.8. LC-424:替换后的最长重复字符 66 2.1.7.9. LC-713:乘积小于K的子数组 67 2.1.7.10. LC-992:K个不同整数的子数组 70 2.3. 左右指针 73 2.3.1. 模板 73 2.3.2. 相关目 73 2.3.2.1. LC-76:删除倒数第N个节点 74 2.3.2.2. LC-61:旋转链表 76 2.3.2.3. LC-80:删除有序数组中的重复项 79 2.3.2.4. LC-86:分割链表 80 2.3.2.5. LC-438:找到字符串中所有字母的异位词 82 3. 模板 85 2.3.2.6. LC-76:删除倒数第N个节点 85
引用\[1\]提供了一个朴素的解法,使用两个来存储字符串,一个用来存储普通字符,另一个用来存储特殊字符。遍历字符串,如果是普通字符则压入第一个,如果是特殊字符则弹出第一个顶元素。最后比较两个是否相同即可判断字符串是否有效。这个解法的时间复杂度是O(M + N),空间复杂度也是O(M + N)。\[1\] 引用\[2\]提供了另一个的应用场景,即判断括号是否有效。遍历字符串,如果是左括号则压入,如果是右括号则判断和顶元素是否匹配,不匹配则返回false,匹配则弹出顶元素。最后判断是否为空即可判断括号是否有效。\[2\] 引用\[3\]也提供了一个判断括号是否有效的解法,使用来操作。遍历字符串,如果是左括号则压入,如果是右括号则判断和顶元素是否匹配,不匹配则返回false,匹配则弹出顶元素。最后判断是否为空即可判断括号是否有效。这个解法使用了HashMap来存储括号的对应关系。\[3\] 综上所述,在解决字符串相关问中有着广泛的应用,包括判断字符串是否有效、逆波兰表达式等。在解决这些问时,可以帮助我们保存和处理字符的顺序,从而简化问的处理过程。 #### 引用[.reference_title] - *1* *3* [Leetcode03-](https://blog.csdn.net/weixin_47802917/article/details/123007699)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v4^insert_chatgpt"}} ] [.reference_item] - *2* [leetCode-类型详解](https://blog.csdn.net/zhiyikeji/article/details/125508011)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v4^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值