The problem of getting maximum of a list is quite generic and we might some day face the issue of getting the maximum of alternate elements and get the list of 2 elements containing maximum of alternate elements. Let’s discuss certain ways in which this can be performed.
Method #1 : Using list comprehension + list slicing + max() List slicing clubbed with list comprehension can be used to perform this particular task. We can have list comprehension to get run the logic and list slicing can slice out the alternate character, maximize by the max function.
Python3
test_list = [ 2 , 1 , 5 , 6 , 8 , 10 ]
print ("The original list : " + str (test_list))
res = [ max (test_list[i : : 2 ]) for i in range ( len (test_list) / / ( len (test_list) / / 2 ))]
print ("The alternate elements maximum list : " + str (res))
|
Output :
The original list : [2, 1, 5, 6, 8, 10]
The alternate elements maximum list : [8, 10]
Time Complexity: O(n), where n is the length of the input list. This is because we’re using the list comprehension + list slicing + max() which has a time complexity of O(n) in the worst case.
Auxiliary Space: O(n), as we’re using additional space res other than the input list itself with the same size of input list.
Method #2 : Using loop This is the brute method to perform this particular task in which we have the maximum of alternate elements in different element indices and then return the output list.
Python3
test_list = [ 2 , 1 , 5 , 6 , 8 , 10 ]
print ("The original list : " + str (test_list))
res = [ 0 , 0 ]
for i in range ( 0 , len (test_list)):
if (i % 2 ):
res[ 1 ] = max (res[ 1 ], test_list[i])
else :
res[ 0 ] = max (res[ 0 ], test_list[i])
print ("The alternate elements maximum list : " + str (res))
|
Output :
The original list : [2, 1, 5, 6, 8, 10]
The alternate elements maximum list : [8, 10]
Time Complexity: O(n) where n is the number of elements in the string list. The loop is used to perform the task and it takes O(n) time.
Auxiliary Space: O(n) additional space of size n is created where n is the number of elements in the res test_list.
Whether you're preparing for your first job interview or aiming to upskill in this ever-evolving tech landscape,
GeeksforGeeks Courses are your key to success. We provide top-quality content at affordable prices, all geared towards accelerating your growth in a time-bound manner. Join the millions we've already empowered, and we're here to do the same for you. Don't miss out -
check it out now!