You are given two arrays (without duplicates) nums1 and nums2 where nums1’s elements are subset of nums2. Find all the next greater numbers for nums1's elements in the corresponding places of nums2.
The Next Greater Number of a number x in nums1 is the first greater number to its right in nums2. If it does not exist, output -1 for this number.
Output: [-1,3,-1]
Explanation:
For number 4 in the first array, you cannot find the next greater number for it in the second array, so output -1.
For number 1 in the first array, the next greater number for it in the second array is 3.
For number 2 in the first array, there is no next greater number for it in the second array, so output -1.
Input: nums1 = [2,4], nums2 = [1,2,3,4].
Output: [3,-1]
Explanation:
For number 2 in the first array, the next greater number for it in the second array is 3.
For number 4 in the first array, there is no next greater number for it in the second array, so output -1.
首先是自己的想法,比較笨拙,就是找到相同的數后驅查找后面比它大的數,找到就終止循環,將數字記入,找不到就記入-1.
def nextGreaterElement(self, findNums, nums):
"""
:type findNums: List[int]
:type nums: List[int]
:rtype: List[int]
"""
gle = []
for i in range(len(findNums)):
flag = False
for j in range(len(nums)):
if findNums[i] == nums[j]:
flag = True
if (flag and nums[j] > findNums[i]):
gle.append(nums[j])
flag = False
break
if flag:
gle.append(-1)
return gle
在網上看其他的方法,用stack的想法:
Suppose we have a decreasing sequence followed by a greater number
For example [5, 4, 3, 2, 1, 6] then the greater number 6 is the next greater element for all previous numbers in the sequence
We use a stack to keep a decreasing sub-sequence, whenever we see a number x greater than stack.peek() we pop all elements less than x and for all the popped ones, their next greater element is x
For example [9, 8, 7, 3, 2, 1, 6]
The stack will first contain [9, 8, 7, 3, 2, 1] and then we see 6 which is greater than 1 so we pop 1 2 3 whose next greater element should be 6
方法如下,用一個字典記錄,記錄比當前這個數大的后面的第一個數:
def nextGreaterElement(self, findNums, nums):
"""
:type findNums: List[int]
:type nums: List[int]
:rtype: List[int]
"""
m = {}
s = []
res = []
for i in nums:
while len(s) and s[-1]<i:
m[s.pop()] = i
s.append(i)
for j in findNums:
res.append(m.get(j,-1))
return res