题目描述
原题链接:496. 下一个更大元素 I
解题思路
暴力解法
Python
class Solution:
def nextGreaterElement(self, nums1: List[int], nums2: List[int]) -> List[int]:
n1, n2 = len(nums1), len(nums2)
res = []
for i in range(n1):
num = nums1[i]
j, index = 0, 0
while j < n2:
if nums2[j] == num:
index = j + 1
while index < n2 and nums2[index] <= num:
index += 1
break
j += 1
if index < n2:
res.append(nums2[index])
else:
res.append(-1)
return res
单调栈
本题与 739. 每日温度 的区别在于,需要先通过让nums1
与nums2
判定出为想等元素后,再去找nums2
中更大的数。
因此,第一步需要找到想等数,第二步需要找到大于的数。
对于第一步,我们可以用Hash表完成nums1
与nums2
中想等元素的映射关系,存储nums1
中下标,采用空间换时间的方式,避免两重for循环。
对于第二步,就采用和每日温度相同的单调栈方式,维持一个从栈底到栈顶的递减栈。当遇到nums1
与nums2
中想等元素时,就记录答案。如果没有遇到就进行正常的入栈,出栈操作。
class Solution {
public:
vector<int> nextGreaterElement(vector<int>& nums1, vector<int>& nums2) {
int n1 = nums1.size(), n2 = nums2.size();
vector<int> res(n1, -1);
unordered_map<int, int> umap;
for(int i = 0; i < n1; i++) umap[nums1[i]] = i;
stack<int> st;
st.push(0);
for(int i = 1; i < n2; i++) {
while(!st.empty() && nums2[st.top()] < nums2[i]) {
if(umap.count(nums2[st.top()]) > 0) {
int index = umap[nums2[st.top()]];
res[index] = nums2[i];
}
st.pop();
}
st.push(i);
}
return res;
}
};
Python
class Solution:
def nextGreaterElement(self, nums1: List[int], nums2: List[int]) -> List[int]:
n1, n2 = len(nums1), len(nums2)
res = []
stack = []
record = {}
for i in range(n2):
while stack and stack[-1] < nums2[i]:
record[stack[-1]] = nums2[i]
stack.pop()
stack.append(nums2[i])
for i in range(n1):
if nums1[i] in record.keys():
res.append(record[nums1[i]])
else:
res.append(-1)
return res
参考文章:496.下一个更大元素 I