代码随想录训练营第五十八天|739.每日温度、496.下一个更大元素

文章介绍了如何用编程方法解决两个LeetCode题目:739.每日温度和496.下一个更大元素。对于每日温度问题,使用单调栈可以优化从O(n^2)到O(n)的时间复杂度;对于下一个更大元素,通过建立哈希表和单调栈,可以在遍历过程中找到每个元素的下一个更大值。
摘要由CSDN通过智能技术生成

739.每日温度

链接:LeetCode739.每日温度

暴力解法—双层for循环

class Solution {
public:
    vector<int> dailyTemperatures(vector<int>& temperatures) {
        vector<int> ans(temperatures.size(),-1);
        for(int i=0;i<temperatures.size();++i){
            for(int j=i+1;j<temperatures.size();++j){
                if(temperatures[j]>temperatures[i]) {ans[i] = j-i;break;}
            }
            if(ans[i]==-1) ans[i]=0;
        }
        return ans;
    }
};

该解法会超时。时间复杂度为O(n^2),空间复杂度为O(n);

单调栈

解题思路:需要一个辅助栈,存储温度以及对应的下标
由于要求的是比当天温度高的天数,所以在存储温度的同时还要存储温度所对应的下标也就是所谓的天数;由于要求的是更高的温度,于是当栈空或者当前温度小于等于栈顶温度时,该温度以及对应的下标进栈;反之,将栈顶元素出栈直到当前温度小于等于栈顶温度(这里使用的while循环)。之后将当前温度以及对应的下标进栈。每次出栈时要进行的操作:当前温度对应的下标-栈顶温度对应的下标就是ans[st.top().second]的值。

class Solution {
public:
    vector<int> dailyTemperatures(vector<int>& temperatures) {
        stack<pair<int,int>> st;//存储温度到天之间的映射
        st.push(pair<int,int>{temperatures[0],0});
        vector<int> ans(temperatures.size(),0);
        for(int i=1;i<temperatures.size();++i){
            while(!st.empty()&&temperatures[i]> st.top().first) {
                ans[st.top().second]=i-st.top().second;
                st.pop();
            }
            st.push(pair<int,int>{temperatures[i],i});
        }
        return ans;
    }
};

496.下一个更大元素

链接:LeetCode496.下一个更大元素
首先将nums1映射到哈希表中,遍历nums2的元素,依次入栈。栈空或者当前元素小于等于栈顶元素入栈;反之出栈直到当前元素小于等于栈顶元素,之后入栈当前元素。

class Solution {
public:
    vector<int> nextGreaterElement(vector<int>& nums1, vector<int>& nums2) {
        //将nums1存储到哈希表中
        unordered_map<int,int>ma;
        for(int i=0;i<nums1.size();++i) ma[nums1[i]] =i;
        vector<int> ans(nums1.size(),-1);
        stack<int> st;//单调栈,存储nums2的元素
        for(int i=0;i<nums2.size();++i){
            while(!st.empty()&&nums2[i]>st.top()){
                auto it = ma.find(st.top());
                if(it!=ma.end()) ans[it->second] = nums2[i];
                st.pop();
            }st.push(nums2[i]);
        }
        return ans;
    }
};
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值