Starter
Have a go at this sorting game. How quickly can you sort all the letters just by clicking on letters to swap?
Introduction
Sorting algorithms – Why do we need them?
One of the most important jobs a computer performs for us is sorting of data. Without sorted data our computer systems would be much harder to use.
Imagine:
- trying to read through all your emails if they were in a random date order.
- finding a friend’s telephone number if all you contacts were in a random order.
- loading an app from your apps list if they were all jumbled up.
There are many different ordering systems we can use, common ones include:
- alphabetical order
- numerical order
- date order
- size order
Different sorting algorithms
There are many different algorithms(methods) for sorting lists of things. In the last task some people will have sorted the letters the fastest (most time efficient) or with the least number of swap (most effort efficient). Have a chat with the person next to about how they sorted out the list. What technique did they use? Whose algorithm was the most time / effort efficient?
In computer science we have many different sorting techniques, some are most efficient than others, some are simpler than others. Today we will be looking at:
- Insertion Sort
- Bubble Sort
- Selection Sort
Insertion Sort
Insertion Sort
With the insertion sort algorithm, you go through each item in the list in turn and move to its correct position in the list. The algorithm is slow but simple.
Insertion Sort Tutorial
Bubble Sort
Bubble Sort
AS & A Level – You are required to know how it works and be able to write Code / Pseudocode for the algorithm
The bubble sort algorithm works by sorting through the array in pairs. It starts at the left of the array and inspects the first two items. If the items are in the wrong order they are swapped around. The algorithm then carries on with the next pair along and so forth. When it reaches the end of the array it goes back to the beginning of the array and starts again. If it completes a full pass of the array without swapping any items it knows that the array is sorted.
Bubble Sort Python Tutorial
Bubble Sort Demonstration
Merge Sort
Merge Sort
Activity 1
Activity 1 – People Sorter
Replicate the class activity for each sorting algorithm (this can be done after introducing each sorting algorithm.
Best splitting the class in to groups of 15 or less (otherwise the sorting will take a rather long time!
Alternative Activity – Have a go at sorting letters using the scratch game below
Scratch Practise