题目:点这里
解法
cpp
class Solution {
public:
vector<int> dailyTemperatures(vector<int>& temperatures) {
vector<int> ans;
vector<int> stc;
for(int i=0;i<temperatures.size();i++){
ans.push_back(0);
}
for(int i=0;i<temperatures.size();i++){
while(stc.size()&&temperatures[stc.back()]<temperatures[i]){
ans[stc.back()] = i-stc.back();
stc.pop_back();
}
stc.push_back(i);
}
return ans;
}
};
这个题目我又一次被栈这个容器的神奇所深深吸引,栈这个容器真是太有魅力了,同样的一道题目,用循环需要双层嵌套,代码又长又臭,而且会超时,用栈的话巧妙解决这个问题。
具体思路就是,首先定义两个栈,一个用来存放最终的答案,一个用来暂存需要比较元素的索引,第一步咱们将答案栈的所有值赋值为0,然后利用for循环的遍历,先将第一个元素,暂存入stc栈中,然后将温度数组中的后续元素与之比较,如若大于,则将两元素索引差传入答案栈,并且弹出stc栈的栈顶元素,否则将其传入stc栈中,紧接着进入下一层循环,再将stc栈的栈顶元素与后续元素进行比较,与前面重复相同的操作。
图示

但我学到的不只有这些。。。
反思
首先这一大段复杂的难以理解的代码不是一气呵成的,它需要我们结合图像分析,并生成初步的,不完善的一次性代码,后续再进行优化,比如:如果if语句和对应的else语句中都存在相同的语句,则就可以把这个重复语句提出来,放在判断的外面 ,另外,我总感觉栈配合循环 能爆发出无限的潜能,但我现在还不能想像出来,但这个题目给了我一点启发,栈配合循环使用的情形,如果一开始想象不到,可以把栈当作一个缓存的变量使用,结合判断,先写执行一次的特殊性代码,然后再转化成普遍性代码,这个就是从个性到共性,从特殊性到普遍性的道理。
还有,
ret.push_back()代表从尾部插入即入栈
ret.back()代表返回尾部元素即返回栈顶元素
ret.pop_back()代表删除尾部元素即出栈