Quicksort Algorithm
Goals
Students will understand elements of the quicksort algorithm, which uses a pivot element to recursively sort a deck of cards quickly.
Video
Materials
One deck of Acorn cards.
data:image/s3,"s3://crabby-images/c4313/c431370a7a95b9088bb999e0d99c456904305760" alt="this is a placeholder image"
Setup
Shuffle the deck and deal each student 8 cards.
Each student will shuffle their 8 cards, and deal them face-down in a row in front of them, as shown below. These will define their initial collection of cards.
Algorithm
Flip up the right-most card of your current collection. This will be the local pivot element.
Now, use the Partition section below to divide your collection into two sub-collections, the cards lower than the pivot, and the cards higher than the pivot.
For each sub-collection that has more than once card, repeat this algorithm.
Now, flip all the cards face-up. They should be in sorted order!
Partition
To start, flip the left-most card of the sub-collection face-up to become the current card.
-
If the number on the current card is less than or equal to the number on the pivot card, swap it with the card immediately to the right of the shifted-up smaller cards. If there are no shifted-up cards, swap it with the left-most card in the collection. Flip the swapped-out card face-up, and the current card face-down. Since the current card is a smaller card, shift it up.
-
If there is a face-down card to the right of the face-up card, then flip this card face-up to become the new current card, flip the face-up card face-down, and repeat the previous step.
Finally, swap the pivot card with the card immediately to the right of the shifted-up smaller cards. If there are no shifted-up cards, swap it with the left-most card in the collection.
Example
Here is an example of this algorithm applied to the cards 25, 06, 47, 54, 29, 35, 67, and 41.
The right-most card 41 of our collection is flipped face-up as our pivot card.
data:image/s3,"s3://crabby-images/a3dcb/a3dcb0a5607db8d35adce0087d0a0850a7b38056" alt="41 flipped up as the pivot card of the collection."
The first current card is the left-most card of the collection 25. 25 is less than our pivot card 41 so it must be shifted up.
There is a face-down card to the right of our current card so we flip our current card 25 face-down and flip the card to the right face-up.
data:image/s3,"s3://crabby-images/aea42/aea42e83f86e5b3be35f3af686ad9260e480bdbd" alt="25 being compared to 41."
The current card 06 is less than our pivot card 41 so it must be shifted up.
There is a face-down card to the right of our current card so we flip our current card 06 face-down and flip the card to the right face-up.
data:image/s3,"s3://crabby-images/44816/448167ee22bb12046abd2f652f3d6259af3a3c8e" alt="06 being compared to 41."
The current card 47 is greater than our pivot card 41 so we continue.
There is a face-down card to the right of our current card so we flip our current card 47 face-down and flip the card to the right face-up.
data:image/s3,"s3://crabby-images/1a834/1a8344325aabbc8cfa775a6a6e3c6de101a7deec" alt="47 being compared to 41."
The current card 54 is greater than our pivot card 41 so we continue.
There is a face-down card to the right of our current card so we flip our current card 54 face-down and flip the card to the right face-up.
data:image/s3,"s3://crabby-images/f076d/f076dcadc1d6aed67f11e98074a69ead937de79c" alt="54 being compared to 41."
The current card 29 is less than our pivot card 41 so it must be shifted up.
The card to the immediate right of our shifted-up cards is swapped into its place.
There is a face-down card to the right of where our current card was so we flip our current card 29 face-down and flip the card to the right face-up.
data:image/s3,"s3://crabby-images/7599f/7599fceb2112782a6f736804ddedc46b4825bd90" alt="29 being compared to 41."
The current card 35 is less than our pivot card 41 so it must be shifted up.
The card to the immediate right of our shifted-up cards is swapped into its place.
There is a face-down card to the right of where our current card was so we flip our current card 35 face-down and flip the card to the right face-up.
data:image/s3,"s3://crabby-images/aa248/aa24859a462c25628d0cc710159d90f839018f62" alt="35 being compared to 41."
The current card 67 is greater than our pivot card 41 so we continue.
There is no face-down card to the right of our current card so we stop and flip the current card face-down.
data:image/s3,"s3://crabby-images/375f5/375f5559ce65381977eea89baf577a6b57ca834b" alt="67 being compared to 41."
The card to the immediate right of our shifted-up cards is swapped with the pivot card.
data:image/s3,"s3://crabby-images/70b85/70b85a2121b843a535e457f032d4e61d17c0a0ba" alt="41 swapping positions with the card to the right of the shifted-up cards."
The shifted up cards will become our current collection.
The right-most card 35 of our collection is flipped face-up as our pivot card.
data:image/s3,"s3://crabby-images/202c0/202c0e75f81c97d0b3cfab0bce6c375faa6dabdc" alt="35 flipped up as the pivot card of the collection."
The first current card is the left-most card of the collection 25. 25 is less than our pivot card 35 so it must be shifted up.
There is a face-down card to the right of our current card so we flip our current card 25 face-down and flip the card to the right face-up.
data:image/s3,"s3://crabby-images/301e3/301e3fc39c3b73565302e7ec8fae3c5eefb50617" alt="25 being compared to 35."
The current card 06 is less than our pivot card 35 so it must be shifted up.
There is a face-down card to the right of our current card so we flip our current card 06 face-down and flip the card to the right face-up.
data:image/s3,"s3://crabby-images/4580c/4580c94ea7f8302ef291f49ec6128c25f1505dbc" alt="06 being compared to 35."
The current card 29 is less than our pivot card 35 so it must be shifted up.
There is no face-down card to the right of our current card so we stop and flip the current card face-down.
data:image/s3,"s3://crabby-images/c424c/c424c38184f1ef2bb1377ad96fe4b2ded265be4f" alt="29 being compared to 35."
The card to the immediate right of our shifted-up cards is swapped with the pivot card.
data:image/s3,"s3://crabby-images/109e8/109e8d9c6ac84d873d238dc4cda2fce84f295518" alt="35 swapping positions with the card to the right of the shifted-up cards."
The shifted up cards will become our current collection.
The right-most card 29 of our collection is flipped face-up as our pivot card.
data:image/s3,"s3://crabby-images/b9990/b999066afe7fff3c5259d4c231c19b1b5dc45edd" alt="29 flipped up as the pivot card of the collection."
The first current card is the left-most card of the collection 25. 25 is less than our pivot card 29 so it must be shifted up.
There is a face-down card to the right of our current card so we flip our current card 25 face-down and flip the card to the right face-up.
data:image/s3,"s3://crabby-images/59a20/59a20ba0118935767a9a43368876504771781a28" alt="25 being compared to 29."
The current card 06 is less than our pivot card 29 so it must be shifted up.
There is no face-down card to the right of our current card so we stop and flip the current card face-down.
data:image/s3,"s3://crabby-images/039bd/039bdf60c6aaad9b92ee23968e736f53ca4a7885" alt="06 being compared to 29."
The card to the immediate right of our shifted-up cards is swapped with the pivot card.
data:image/s3,"s3://crabby-images/bac87/bac87facf4c5cab961cf2236b239d95477714c35" alt="29 swapping positions with the card to the right of the shifted-up cards."
The shifted up cards will become our current collection.
The right-most card 06 of our collection is flipped face-up as our pivot card
data:image/s3,"s3://crabby-images/78e55/78e55b543b6fae343d3ce6a7372e72bdfbb9a05f" alt="06 flipped up as the pivot card of the collection."
The first current card is the left-most card of the collection 25. 25 is greater than our pivot card 06 so we continue.
There is no face-down card to the right of our current card so we stop and flip the current card face-down.
data:image/s3,"s3://crabby-images/e3715/e37159d743f30689f7b03ccf60eec3177757504b" alt="25 being compared to 06."
Since there are no shifted up cards, the left-most card in the collection is swapped with the pivot card.
data:image/s3,"s3://crabby-images/f4f28/f4f289bef0b49c0f432ad003e2cc87754c7dfd24" alt="29 swapping positions with left-most card."
There is only one card in the next collection, so it is flipped face-up.
data:image/s3,"s3://crabby-images/8885e/8885e44f1948216a121d3e0b9cd311ed82826d8b" alt="25 flipped face-up."
The cards that have never been shifted-up become our current collection.
The right-most card 47 of our collection is flipped face-up as our pivot card
data:image/s3,"s3://crabby-images/326a5/326a5f3f8a98bcb402434cd734dd70a237c69dc7" alt="47 flipped up as the pivot card of the collection."
The first current card is the left-most card of the collection 54. 54 is greater than our pivot card 47 so we continue.
There is a face-down card to the right of our current card so we flip our current card 54 face-down and flip the card to the right face-up.
data:image/s3,"s3://crabby-images/c1d84/c1d847fa6917c2f46335c78a2f4974d34a898ed9" alt="54 being compared to 47."
The current card 67 is greater than our pivot card 47 so we continue.
There is no face-down card to the right of our current card so we stop and flip the current card face-down.
data:image/s3,"s3://crabby-images/8d523/8d523a7375376f6c9702defbd08cf9ceb9ed7e89" alt="67 being compared to 47."
Since there are no shifted up cards, the left-most card in the collection is swapped with the pivot card.
data:image/s3,"s3://crabby-images/6bff0/6bff01c97892911c354490baa9e0259017212d57" alt="47 swapping positions with left-most card."
The cards that have never been shifted-up become our current collection.
The right-most card 54 of our collection is flipped face-up as our pivot card
data:image/s3,"s3://crabby-images/ba915/ba9157b131cafd976ff0c47e2f077bc0dacb3a60" alt="54 flipped up as the pivot card of the collection."
The first current card is the left-most card of the collection 67. 67 is greater than our pivot card 54 so we continue.
There is no face-down card to the right of our current card so we stop and flip the current card face-down.
data:image/s3,"s3://crabby-images/9f905/9f90588d043074d8d26d9c8b1c2b108eea5b6532" alt="67 being compared to 54."
Since there are no shifted up cards, the left-most card in the collection is swapped with the pivot card.
data:image/s3,"s3://crabby-images/c508a/c508a2c16e1dc36638c21a66a519cfc9a9386f54" alt="54 swapping positions with left-most card."
There is only one card in the next collection, so it is flipped face-up.
data:image/s3,"s3://crabby-images/b82ee/b82ee78896eecbbf3e73bbede51f19a4d74604f4" alt="67 flipped face-up."
Finished
Now all the cards should be flipped up and in sorted order.