Skip to content
Advertisement

Finding a next lowest number from a List in python

I have a list of arrays as follows: Array =[3, 6, 5, 7, 2, 4, 3, 5, 4, 5, 4, 7, 6, 7, 1, 7, 4, 6, 3]

example: Value = 3, 6, 5, 7, 2, 4, 3, 5, 4, 5, 4, 7, 6, 7, 1, 7, 4, 6, 3

valley/Peak = v, p, v, p, v, p, v, p, v, p, v, p, v, p, v, p, v, p,v

enter image description here

Advertisement

Answer

logic

assign the index to start from

assign the value of the starting index

make a loop starting from the starting index to the end of the loop

in the loop check if current number is smaller than the starting target

slice the list to create the result sublist

code

array = [3, 6, 5, 7, 2, 4, 3, 5, 4, 5, 4, 7, 6, 7, 1, 7, 4, 6, 3]

start_index = 0  # the index to start from

# start_index = int(input("Enter the index to start from: ")) # to take this a step further, you could ask the user for the index to start from

target = array[start_index]  # the number in the starting index

for i in range(start_index, len(array)):  # loop from the start index till the end
    if array[i] < target:  # if the current number is smaller than my traget
        # split the list from the start index to the current index (+1 because the slice is not inclusive)
        print(array[start_index:i+1])
        break
    if i == len(array)-1:  # if we reached the end of the list
        print('fail')  # print the rest of the list

input

start_index = 0

array = [3, 6, 5, 7, 2, 4, 3, 5, 4, 5, 4, 7, 6, 7, 1, 7, 4, 6, 3]

output

[3, 6, 5, 7, 2]

User contributions licensed under: CC BY-SA
7 People found this is helpful
Advertisement