Introduction and Lesson Plan

Hello, learner! Today, we're delving into quick sort, a swift sorting algorithm akin to sorting toys by size. We'll explore how it works and implement it in TypeScript, so hang tight!

Quick sort, devised by Tony Hoare in 1959, leverages the divide-and-conquer strategy. It selects a pivot element and then arranges all smaller elements to one side and larger ones to the other.

Quick Sort Under The Hood

Quick sort operates in three steps:

  1. Selecting a pivot.
  2. Shifting elements smaller than the pivot to one side and moving elements larger than the pivot to the other side.
  3. Repeating these steps for both sides separately.

Consider, for instance, sorting [3, 9, 4, 7, 5, 1, 6, 2, 8] with 7 as the pivot. After one round, it becomes [3, 4, 5, 1, 6, 2, 7, 9, 8]. The pivot 7 is correctly placed, and we can then divide the array into two parts: [3, 4, 5, 1, 6] and [9, 8], which can be sorted separately.

Quick Sort Implementation in TypeScript: Partition

Let's implement quick sort in TypeScript. First, we partition the array around the pivot in our partition function:

In this portion of the code, we select the last element as the pivot and place smaller elements on the left.

The function starts by initializing i to one index before the low. This i basically keeps track of the latest position where an element has been swapped because it was less than or equal to the pivot. If arr[j] is less than or equal to the pivot, i is incremented, and then arr[j] is swapped with arr[i]. Essentially, smaller elements get pushed towards the front of the array (or the given part of the array).

The low and high parameters control which part of the given array is under the partition operation. Using these parameters, we can apply the partition to some part of the array, which will be helpful later.

Quick Sort Implementation in TypeScript: Sorting

Then, we apply quick sort with a function that invokes partition and recursively sorts the two halves:

Spot on! We've just created a fully functioning quick sort algorithm in TypeScript.

Honing In On Quick Sort Efficiency

The time complexity of quick sort can vary. Generally speaking, the more unique items there are, the quicker quick sort works. In the best and average cases, it shines with a time complexity of O(nlogn)O(n \log n). However, the time complexity can degrade to O(n2)O(n^2) in the worst case.

Lesson Summary and Next Steps

Kudos! You've mastered the basics of quick sort and its implementation in TypeScript and have analyzed its time complexity. Up next, we have engaging practice exercises lined up. Are you ready to flex your newly acquired skills?

Sign up
Join the 1M+ learners on CodeSignal
Be a part of our community of 1M+ users who develop and demonstrate their skills on CodeSignal