TheAlgorithms-Python/data_structures/stacks/next_greater_element.py

87 lines
2.8 KiB
Python
Raw Normal View History

arr = [-10, -5, 0, 5, 5.1, 11, 13, 21, 3, 4, -21, -10, -5, -1, 0]
def next_greatest_element_slow(arr):
"""
Function to get Next Greatest Element (NGE) pair for all elements of list
Maximum element present afterwards the current one which is also greater than current one
>>> next_greatest_element_slow(arr)
[-5, 0, 5, 5.1, 11, 13, 21, -1, 4, -1, -10, -5, -1, 0, -1]
"""
result = []
2018-10-19 20:48:28 +08:00
for i in range(0, len(arr), 1):
next = -1
2019-10-05 13:14:13 +08:00
for j in range(i + 1, len(arr), 1):
2018-10-19 20:48:28 +08:00
if arr[i] < arr[j]:
next = arr[j]
break
result.append(next)
return result
def next_greatest_element_fast(arr):
"""
Like next_greatest_element_slow() but changes the loops to use
enumerate() instead of range(len()) for the outer loop and
for in a slice of arr for the inner loop.
>>> next_greatest_element_fast(arr)
[-5, 0, 5, 5.1, 11, 13, 21, -1, 4, -1, -10, -5, -1, 0, -1]
"""
result = []
for i, outer in enumerate(arr):
next = -1
for inner in arr[i + 1:]:
if outer < inner:
next = inner
break
result.append(next)
return result
def next_greatest_element(arr):
"""
Function to get Next Greatest Element (NGE) pair for all elements of list
Maximum element present afterwards the current one which is also greater than current one
Naive way to solve this is to take two loops and check for the next bigger number but that will make the
time complexity as O(n^2). The better way to solve this would be to use a stack to keep track of maximum
number givig a linear time complex solution.
>>> next_greatest_element(arr)
[-5, 0, 5, 5.1, 11, 13, 21, -1, 4, -1, -10, -5, -1, 0, -1]
"""
stack = []
result = [-1]*len(arr)
for index in reversed(range(len(arr))):
if len(stack):
while stack[-1] <= arr[index]:
stack.pop()
if len(stack) == 0:
break
if len(stack) != 0:
result[index] = stack[-1]
stack.append(arr[index])
return result
if __name__ == "__main__":
from doctest import testmod
from timeit import timeit
testmod()
print(next_greatest_element_slow(arr))
print(next_greatest_element_fast(arr))
print(next_greatest_element(arr))
2019-10-05 13:14:13 +08:00
setup = ("from __main__ import arr, next_greatest_element_slow, "
"next_greatest_element_fast, next_greatest_element")
print("next_greatest_element_slow():",
timeit("next_greatest_element_slow(arr)", setup=setup))
print("next_greatest_element_fast():",
timeit("next_greatest_element_fast(arr)", setup=setup))
print(" next_greatest_element():",
timeit("next_greatest_element(arr)", setup=setup))