题目

类型:Array
image.png

解题思路

使用单调栈+哈希表
倒序遍历 nums 2,并用单调栈中维护当前位置右边的更大的元素列表,从栈底到栈顶的元素是单调递减的。
每次移动到数组中一个新的位置 i,就将当前单调栈中所有小于nums 2[i] 的元素弹出栈,当前位置右边的第一个更大的元素即为栈顶元素,如果栈为空则说明当前位置右边没有更大的元素。随后我们将位置 i 的元素入栈。
将元素值与其右边第一个更大的元素值的对应关系存入哈希表。

代码

  1. public int[] nextGreaterElement(int[] nums1, int[] nums2) {
  2. Map<Integer, Integer> map = new HashMap<Integer, Integer>();
  3. Deque<Integer> stack = new ArrayDeque<Integer>();
  4. for (int i = nums2.length - 1; i >= 0; --i) {
  5. int num = nums2[i];
  6. while (!stack.isEmpty() && num >= stack.peek()) {
  7. stack.pop();
  8. }
  9. map.put(num, stack.isEmpty() ? -1 : stack.peek());
  10. stack.push(num);
  11. }
  12. int[] res = new int[nums1.length];
  13. for (int i = 0; i < nums1.length; ++i) {
  14. res[i] = map.get(nums1[i]);
  15. }
  16. return res;
  17. }