503.下一个更大元素II
思路: 循环数组中得到元素下一个比它大的值,那么可以将两个本数组拼接,遍历即可。按照739. 每日温度的方法,在拼接数组中进行寻找。
class Solution {
public:
vector<int> nextGreaterElements(vector<int>& nums) {
vector<int> result(nums.size(),-1);
if(nums.size()==0){
return result;
}
stack<int> st;
st.push(0);
for(int i=1;i<nums.size()*2;i++){
if(nums[i%nums.size()]<=nums[st.top()]){
st.push(i%nums.size());
}
else{
while(!st.empty()&&nums[i%nums.size()] > nums[st.top()]){
result[st.top()] = nums[i%nums.size()];
st.pop();
}
st.push(i%nums.size());
}
}
return result;
}
};
42. 接雨水
思路: 本体相当于求一个左右大于当前元素的位置,然后计算面积。要求左右比当前元素大,可以使用单调栈,使用递增栈,若当前元素大于栈顶,那么height[i]与栈顶的下一个元素就为他的左右元素,取最小h,计算宽度,即可得到现在的与水量。然后遍历所有元素。
class Solution {
public:
int trap(vector<int>& height) {
stack<int> st;
st.push(0);
int result = 0;
for (int i = 1; i < height.size(); i++) {
if (height[i] < height[st.top()]) {
st.push(i);
} else if (height[i] == height[st.top()]) {
st.pop();
st.push(i);
} else {
while (!st.empty() && height[i] > height[st.top()]) {
int mid = height[st.top()];
st.pop();
if (!st.empty()) {
int h = min(height[i], height[st.top()]) - mid;
int w = i - st.top() - 1;
result += h * w;
}
}
st.push(i);
}
}
return result;
}
};