男男做暧网站免费,网站强制qq弹窗代码,企业微信网站怎么建设,wordpress主题 四亩田目录
739 每日温度
496 下一个更大元素 | 739 每日温度 求后面第一个比他大的元素的位置#xff0c;单调栈如果递增 求后面第一个比他小的元素的位置#xff0c;单调栈需要递减 class Solution {
public:vectorint dailyTemperatures(vectorint tempe…目录
739 每日温度
496 下一个更大元素 | 739 每日温度 求后面第一个比他大的元素的位置单调栈如果递增 求后面第一个比他小的元素的位置单调栈需要递减 class Solution {
public:vectorint dailyTemperatures(vectorint temperatures) {stackint st;//求的是后面第一个比他大的元素的位置所以单调栈需要递增vectorint res(temperatures.size(),0);//使得递增st.push(0);//存放temperatures的下标for(int i 1;i temperatures.size();i){if(temperatures[i] temperatures[st.top()]){st.push(i);}else{while(!st.empty() temperatures[i] temperatures[st.top()]){//确保单调栈递增res[st.top()] i - st.top();st.pop();}st.push(i);}}return res;}
};
时间复杂度O(n)
空间复杂度O(n)
496 下一个更大元素 | 求后面第一个比他大的元素的位置单调栈如果递增 求后面第一个比他小的元素的位置单调栈需要递减 class Solution {
public:vectorint nextGreaterElement(vectorint nums1, vectorint nums2) {stackintst;vectorintres(nums1.size(),-1);unordered_mapint,intmp;for(int i 0;i nums1.size();i){//key:下标元素 value:下标mp[nums1[i]] i;//将nums1中的数据存放到mp中}st.push(0);//存放下标for(int i 1;i nums2.size();i){if(nums2[i] nums2[st.top()]){//求后面第一个比他大的元素的位置单调栈如果递增st.push(i);}else{//确保单调栈单调递增while(!st.empty() nums2[i] nums2[st.top()]){//找到自己的位置才停止if(mp.count(nums2[st.top()]) 0){//nums1中存在这个元素int idx mp[nums2[st.top()]];res[idx] nums2[i];}st.pop();}st.push(i);}}return res;}
};
时间复杂度O(mn)//m是nums1的长度n是nums2的长度
空间复杂度O(n)