💾 Archived View for gem.sdf.org › s.kaplan › cheatsheets › data-structures-and-algorithms › quicksor… captured on 2024-09-29 at 01:09:01.

View Raw

More Information

⬅️ Previous capture (2023-09-08)

-=-=-=-=-=-=-

# Quicksort Cheatsheet

## Overview

- Quicksort is a divide-and-conquer sorting algorithm.
- It works by selecting a 'pivot' element from the array and partitioning the other elements into two sub-arrays, according to whether they are less than or greater than the pivot.
- The sub-arrays are then sorted recursively.

## Algorithm

def quicksort(arr, start, end):

if start < end:

# Partition the array

pivot_index = partition(arr, start, end)

# Sort the left sub-array

quicksort(arr, start, pivot_index - 1)

# Sort the right sub-array

quicksort(arr, pivot_index + 1, end)

def partition(arr, start, end):

# Select the pivot element

pivot = arr[end]

# Initialize the pivot index

pivot_index = start

# Partition the array

for i in range(start, end):

if arr[i] < pivot:

arr[i], arr[pivot_index] = arr[pivot_index], arr[i]

pivot_index += 1

# Move the pivot element to its final position

arr[pivot_index], arr[end] = arr[end], arr[pivot_index]

# Return the pivot index

return pivot_index


## Time Complexity

-  Worst-case performance: O(n^2)
-  Best-case performance: O(n log n)
-  Average-case performance: O(n log n)

## Resources

- [Quicksort Wikipedia](https://en.wikipedia.org/wiki/Quicksort)
- [GeeksforGeeks: Quicksort](https://www.geeksforgeeks.org/quick-sort/)
- [Visualgo: Quicksort](https://visualgo.net/en/sorting)