Linear arrays: Difference between revisions
Mr. MacKenty (talk | contribs) No edit summary |
Mr. MacKenty (talk | contribs) |
||
(14 intermediate revisions by the same user not shown) | |||
Line 3: | Line 3: | ||
There are four common algorithms we use on a linear array. Although the IB asks only for you to know these at the pseudocode level, I suggest you memorize these for the rest of your life. | There are four common algorithms we use on a linear array. Although the IB asks only for you to know these at the pseudocode level, I suggest you memorize these for the rest of your life. | ||
You will remember | You will remember we use [[arrays|arrays]] to hold values of the same type at contiguous memory locations. In particular, the use of arrays allows us to create "groups" or "clusters" of variables without needing to give a unique variable name to each, but still allowing us to individually index into the elements of the array.<ref>http://cs50.wiki/Arrays+and+strings</ref> | ||
== Standard algorithms == | |||
* Sequential search | * Sequential search | ||
Line 10: | Line 12: | ||
* Selection sort | * Selection sort | ||
=== Sequential search === | |||
In computer science, linear search or sequential search is a method for finding a target value within a list. It sequentially checks each element of the list for the target value until a match is found or until all the elements have been searched.<ref>https://en.wikipedia.org/wiki/Linear_search</ref> | |||
=== Binary Search === | |||
In computer science, binary search, also known as half-interval search, is a search algorithm that finds the position of a target value within a '''sorted''' array (''emphasis mine''). Binary search compares the target value to the middle element of the array; if they are unequal, the half in which the target cannot lie is eliminated and the search continues on the remaining half until it is successful. If the search ends with the remaining half being empty, the target is not in the array.<ref>https://en.wikipedia.org/wiki/Binary_search_algorithm</ref> | |||
* [https://www.cs.usfca.edu/~galles/visualization/Search.html Click here for a good visualization of binary search] | |||
=== Bubble sort === | |||
Bubble sort, sometimes referred to as sinking sort, is a simple sorting algorithm that repeatedly steps through the list to be sorted, compares each pair of adjacent items and swaps them if they are in the wrong order. The pass through the list is repeated until no swaps are needed, which indicates that the list is sorted. <ref>https://en.wikipedia.org/wiki/Bubble_sort</ref> | |||
* [https://visualgo.net/bn/sorting This is a good animation which not only shows bubble sorts, but also shows the code stepping through a sort] | |||
<syntaxhighlight lang=python> | |||
# Thank you to Alex for submitting this code!!! | |||
def bubbleSort(list): | |||
swapped = True | |||
index_of_last_element = len(list)-1 | |||
while swapped: | |||
swapped = False | |||
for i in range(0,index_of_last_element): | |||
if list[i] > list[(i+1)]: | |||
firstNumber = list[i] | |||
secondNumber = list[(i+1)] | |||
list[i] = secondNumber | |||
list[(i+1)] = firstNumber | |||
swapped=True | |||
index_of_last_element -= 1 | |||
return list | |||
</syntaxhighlight> | |||
=== Selection Sort === | |||
In computer science, selection sort is a sorting algorithm, specifically an in-place comparison sort. The algorithm divides the input list into two parts: the sublist of items already sorted, which is built up from left to right at the front (left) of the list, and the sublist of items remaining to be sorted that occupy the rest of the list. Initially, the sorted sublist is empty and the unsorted sublist is the entire input list. The algorithm proceeds by finding the smallest (or largest, depending on sorting order) element in the unsorted sublist, exchanging (swapping) it with the leftmost unsorted element (putting it in sorted order), and moving the sublist boundaries one element to the right.<ref>https://en.wikipedia.org/wiki/Selection_sort</ref> | |||
<br /> | |||
I'm grateful to wikipedia for the code below<ref>https://en.wikipedia.org/wiki/Selection_sort</ref> | |||
<br /> | |||
<syntaxhighlight lang="python"> | |||
Sorted sublist == ( ) | |||
Unsorted sublist == (11, 25, 12, 22, 64) | |||
Lowest element in unsorted list == 11 | |||
Sorted sublist == (11) | |||
Unsorted sublist == (25, 12, 22, 64) | |||
Lowest element in unsorted list == 12 | |||
Sorted sublist == (11, 12) | |||
Unsorted sublist == (25, 22, 64) | |||
Lowest element in unsorted list == 22 | |||
Sorted sublist == (11, 12, 22) | |||
Unsorted sublist == (25, 64) | |||
Lowest element in unsorted list == 25 | |||
Sorted sublist == (11, 12, 22, 25) | |||
Unsorted sublist == (64) | |||
Lowest element in unsorted list == 64 | |||
Sorted sublist == (11, 12, 22, 25, 64) | |||
Unsorted sublist == ( ) | |||
</syntaxhighlight> | |||
== Do you understand this? == | == Do you understand this? == | ||
[https://www.toptal.com/developers/sorting-algorithms This site is truly excellent resource to help you visually better understand sorting] | |||
== Standards == | == Standards == |
Latest revision as of 08:05, 13 April 2022
There are four common algorithms we use on a linear array. Although the IB asks only for you to know these at the pseudocode level, I suggest you memorize these for the rest of your life.
You will remember we use arrays to hold values of the same type at contiguous memory locations. In particular, the use of arrays allows us to create "groups" or "clusters" of variables without needing to give a unique variable name to each, but still allowing us to individually index into the elements of the array.[2]
Standard algorithms[edit]
- Sequential search
- Binary search
- Bubble sort
- Selection sort
Sequential search[edit]
In computer science, linear search or sequential search is a method for finding a target value within a list. It sequentially checks each element of the list for the target value until a match is found or until all the elements have been searched.[3]
Binary Search[edit]
In computer science, binary search, also known as half-interval search, is a search algorithm that finds the position of a target value within a sorted array (emphasis mine). Binary search compares the target value to the middle element of the array; if they are unequal, the half in which the target cannot lie is eliminated and the search continues on the remaining half until it is successful. If the search ends with the remaining half being empty, the target is not in the array.[4]
Bubble sort[edit]
Bubble sort, sometimes referred to as sinking sort, is a simple sorting algorithm that repeatedly steps through the list to be sorted, compares each pair of adjacent items and swaps them if they are in the wrong order. The pass through the list is repeated until no swaps are needed, which indicates that the list is sorted. [5]
# Thank you to Alex for submitting this code!!!
def bubbleSort(list):
swapped = True
index_of_last_element = len(list)-1
while swapped:
swapped = False
for i in range(0,index_of_last_element):
if list[i] > list[(i+1)]:
firstNumber = list[i]
secondNumber = list[(i+1)]
list[i] = secondNumber
list[(i+1)] = firstNumber
swapped=True
index_of_last_element -= 1
return list
Selection Sort[edit]
In computer science, selection sort is a sorting algorithm, specifically an in-place comparison sort. The algorithm divides the input list into two parts: the sublist of items already sorted, which is built up from left to right at the front (left) of the list, and the sublist of items remaining to be sorted that occupy the rest of the list. Initially, the sorted sublist is empty and the unsorted sublist is the entire input list. The algorithm proceeds by finding the smallest (or largest, depending on sorting order) element in the unsorted sublist, exchanging (swapping) it with the leftmost unsorted element (putting it in sorted order), and moving the sublist boundaries one element to the right.[6]
I'm grateful to wikipedia for the code below[7]
Sorted sublist == ( )
Unsorted sublist == (11, 25, 12, 22, 64)
Lowest element in unsorted list == 11
Sorted sublist == (11)
Unsorted sublist == (25, 12, 22, 64)
Lowest element in unsorted list == 12
Sorted sublist == (11, 12)
Unsorted sublist == (25, 22, 64)
Lowest element in unsorted list == 22
Sorted sublist == (11, 12, 22)
Unsorted sublist == (25, 64)
Lowest element in unsorted list == 25
Sorted sublist == (11, 12, 22, 25)
Unsorted sublist == (64)
Lowest element in unsorted list == 64
Sorted sublist == (11, 12, 22, 25, 64)
Unsorted sublist == ( )
Do you understand this?[edit]
This site is truly excellent resource to help you visually better understand sorting
Standards[edit]
These standards are used from the IB Computer Science Subject Guide[8]
- Describe the characteristics of standard algorithms on linear arrays.
References[edit]
- ↑ http://www.flaticon.com/
- ↑ http://cs50.wiki/Arrays+and+strings
- ↑ https://en.wikipedia.org/wiki/Linear_search
- ↑ https://en.wikipedia.org/wiki/Binary_search_algorithm
- ↑ https://en.wikipedia.org/wiki/Bubble_sort
- ↑ https://en.wikipedia.org/wiki/Selection_sort
- ↑ https://en.wikipedia.org/wiki/Selection_sort
- ↑ IB Diploma Programme Computer science guide (first examinations 2014). Cardiff, Wales, United Kingdom: International Baccalaureate Organization. January 2012.