题目:
请根据每日 气温 列表 temperatures ,重新生成一个列表,要求其对应位置的输出为:要想观测到更高的气温,至少需要等待的天数。如果气温在这之后都不会升高,请在该位置用 0 来代替。
示例:
示例 1:
输入: temperatures = [73,74,75,71,69,72,76,73]
输出: [1,1,4,2,1,1,0,0]
示例 2:
输入: temperatures = [30,40,50,60] 输出: [1,1,1,0]
示例 3:
输入: temperatures = [30,60,90] 输出: [1,1,0]
算法思路:
找第一个比当前值大的值,可以使用栈,把找到大值的出栈,没找到的入栈,栈中的排列从栈顶到栈底依次变大,(从上到下,从小到大)
为什么使用栈而不是队列:(尽量解释,不是很清晰,学一学再回来继续解释)
因为刚存入容器中的是比较小的,而越小越容易出栈,不变的逻辑是,我们希望找到大数时候出容器,(如果找到大数时候存容器,不便于比较,不知道什么时候需要存容器),栈就便于依次比较然后出栈,也可以恰到好处的停止出栈。
第一次code:
class Solution {
public:
vector<int> dailyTemperatures(vector<int>& temperatures) {
stack<int> newst;
int len = sizeof(temperatures) / sizeof(temperatures[0]);
int arr[len];
for (int i = 0; i < len; i++)
arr[i] = 0;
for (int i = 0; i < len; i++) {
if (newst.empty())
newst.push(i);
else {
if (temperatures[i] <= newst.top()) {
newst.push(i);
}
while (temperatures[i] > temperatures[newst.top()] && !newst.empty()) {
arr[newst.top()] = i - newst.top();
newst.pop();
}
}
}
return {};
}
};
修改:
修改1:这里有一个 致命的错误,while循环中,需要先判断栈部位空再比较大小
修改2:以上其实开一看出,算法是冗余的,因为在for循环中,只有while里面需要pop,剩下的情况都是push。
细小语法修改:
修改3:整型数组的长度可以使用in len=temperatures.size();
修改4:int arr[len];要修改成vector<int> arr(len);这样与定义的函数同类型都是vector<int>,便于返回arr
修改5:数组的定义和初始化可以合在一起,数组arr中都初始为0,可以使用vector<int> arr(len,0);
class Solution
{
public:
vector<int> dailyTemperatures(vector<int>& temperatures)
{
stack<int> newst;
int len = temperatures.size();
vector<int> arr(len,0);
for (int i = 0; i < len; i++)
{
while (!newst.empty()&&temperatures[i] > temperatures[newst.top()] )
{
int index=newst.top();
arr[index] = i - index;
newst.pop();
}
newst.push(i);
}
return arr;
}
};
需要加强记忆的地方:(栈)
栈的使用不太熟练
栈名.top/pop();
栈名.push(需要入栈的元素);
本文介绍了一种使用栈实现的算法,用于计算气温列表中每个位置需要等待多少天才能观测到更高的气温。算法利用栈存储较小的温度值,当遇到更大的温度时,计算并更新等待天数。最后返回一个新列表表示升高的天数,否则用0表示。
389





