Skip to content

anversa-pro/sorting_algorithms

Repository files navigation

C

Sorting algorithms & Big O

Learning objectives

  • At least four different sorting algorithms
  • What is the Big O notation, and how to evaluate the time complexity of an algorithm
  • How to select the best sorting algorithm for a given input
  • What is a stable sorting algorithm

Concept

In computer science, a sorting algorithm is an algorithm that puts elements of a list into an order. The most frequently used orders are numerical order and lexicographical order, and either ascending or descending. Efficient sorting is important for optimizing the efficiency of other algorithms (such as search and merge algorithms) that require input data to be in sorted lists. Sorting is also often useful for canonicalizing data and for producing human-readable output.

Formally, the output of any sorting algorithm must satisfy two conditions:

  • The output is in monotonic order (each element is no smaller/larger than the previous element, according to the required order).
  • The output is a permutation (a reordering, yet retaining all of the original elements) of the input.
  • For optimum efficiency, the input data should be stored in a data structure which allows random access rather than one that allows only sequential access.

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages