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;}
};