遍历跳跃
class Solution {
public int[] dailyTemperatures(int[] temperatures) {
int n=temperatures.length;
int[] dp=new int[n];
dp[n-1]=0;
for(int i=n-2;i>=0;--i){
int j=i+1;
//temp标记是否原地踏步
int temp=j;
do{
if(temperatures[i]<temperatures[j]){
dp[i]=j-i;
break;
}
temp=j;
j+=dp[j];
}while(temp!=j&&j<n);
}
return dp;
}
}
public int[] dailyTemperatures(int[] T) {
int length = T.length;
int[] result = new int[length];
//从右向左遍历
for (int i = length - 2; i >= 0; i--) {
// j+= result[j]是利用已经有的结果进行跳跃
for (int j = i + 1; j < length; j+= result[j]) {
if (T[j] > T[i]) {
result[i] = j - i;
break;
} else if (result[j] == 0) { //遇到0表示后面不会有更大的值,那当然当前值就应该也为0
result[i] = 0;
break;
}
}
}
return result;
}
栈
class Solution {
public int[] dailyTemperatures(int[] temperatures) {
int length = temperatures.length;
int[] ans = new int[length];
Deque<Integer> stack = new LinkedList<Integer>();
for (int i = 0; i < length; i++) {
int temperature = temperatures[i];
while (!stack.isEmpty() && temperature > temperatures[stack.peek()]) {
int prevIndex = stack.pop();
ans[prevIndex] = i - prevIndex;
}
stack.push(i);
}
return ans;
}
}