ComeçarComece gratuitamente

Implementação do algoritmo de seleção rápida

Neste exercício, você implementará o algoritmo quicksort para classificar uma lista de números.

Na primeira etapa, você implementará a função partition(), que retorna o índice do pivô depois de processar a lista de números de modo que todos os elementos à esquerda do pivô sejam menores que o pivô e todos os elementos à direita do pivô sejam maiores que o pivô.

Na segunda etapa, você implementará a função quicksort(), que chamará a função partition().

Este exercício faz parte do curso

Estruturas de dados e algoritmos em Python

Ver Curso

Exercício interativo prático

Experimente este exercício preenchendo este código de exemplo.

def partition(my_list, first_index, last_index):
  pivot = my_list[first_index]
  left_pointer = first_index + 1
  right_pointer = last_index
 
  while True:
    # Iterate until the value pointed by left_pointer is greater than pivot or left_pointer is greater than last_index
    while ____ < ____ and ____ < ____:
      left_pointer += 1
    
    while my_list[right_pointer] > pivot and right_pointer >= first_index:
      right_pointer -= 1 
    if left_pointer >= right_pointer:
        break
    # Swap the values for the elements located at the left_pointer and right_pointer
    my_list[left_pointer], my_list[right_pointer] = ____, ____
   
  my_list[first_index], my_list[right_pointer] = my_list[right_pointer], my_list[first_index]
  return right_pointer
Editar e executar código