栈
最近研究到栈了。栈的道理很简单,FILO 先进后出。但是,要想在实际应用中彻底理解应用栈,还是有一定难度。主要是想不起来用栈解决,即使告诉我可以用栈解决,也想不到到底如何用栈。
目前还没有好的思路。但是归根结底,栈还是用来存储数据的,栈可以作为辅助。一般用栈的top元素和其他元素进行比较。true的话,pop栈顶元素。false,继续push。目前只能理解到这里。
请根据每日 气温 列表,重新生成一个列表。对应位置的输出为:要想观测到更高的气温,至少需要等待的天数。如果气温在这之后都不会升高,请在该位置用 0 来代替。
例如,给定一个列表 temperatures = [73, 74, 75, 71, 69, 72, 76, 73],你的输出应该是 [1, 1, 4, 2, 1, 1, 0, 0]。
提示:气温 列表长度的范围是 [1, 30000]。每个气温的值的均为华氏度,都是在 [30, 100] 范围内的整数。
class Solution {
public:
vector<int> dailyTemperatures(vector<int>& T) {
stack<int> temp;
vector<int> ans(T.size(),0);
for(int i=0;i<T.size();i++){
while(!temp.empty()&&T[i]>T[temp.top()]){
ans[temp.top()]=i-temp.top();
temp.pop();
}
temp.push(i);
}
return ans;
}
};
解题思路就是自左至右遍历温度列表元素,要是大的(是本题想要的),就做处理;不是,就暂存在栈中,继续向下,如果一直没找到大的,栈会越来越大,要返回的结果元素是0(说明右面没有大的) 这里的栈叫做单调栈,就是栈中的元素是有单调顺序的。