Sorting and Searching Algorithms Flashcards

Master the sorting algorithms

1
Q

what is a bubble sort?

(Compares)

A

a simple sorting algorithm that
-Compare the first two items in the list to check if they are in the correct order if not then swap them
-Repeat step 1 for items 2 and 3 in the list
-Continue step 1 until all items in the list are sorted

How well did you know this?
1
Not at all
2
3
4
5
Perfectly
2
Q

An example of bubble sort Looks like:

A

1 2 3 4
|4 7 6 3 | 4 and 7 are fine but 6<7
<->
|4 6 7 3 | 6 and 7 swapped but now 3<7so need swap
<->
|4 6 3 7 | 3 and 7 swapped but 6>3 so need to swap
<->
|4 3 6 7 | 3 and 6 swapped but now 4 and3needswap
<->
|3 4 6 7 | Everything is sorted

How well did you know this?
1
Not at all
2
3
4
5
Perfectly
3
Q

How do you write a bubble sort in psuedocode (OCR)

A

array nums[5] = (4,3,2,1,0)
swapped = true
WHILE swapped == true
swapped = false
FOR i = 0 to nums.Lenght-2
IF List[i] > List[i+1] THEN
temp = nums[i]
nums[i] = nums[i+1]
nums[i+1] = temp
swapped = true
ENDIF
NEXT i
ENDWHILE

How well did you know this?
1
Not at all
2
3
4
5
Perfectly
4
Q

What is an Insertion sort?

(All in one go)

A

It is a simple sorting algorithm that follows the steps of;
-places each item one at a time into the correct position
-First Item in the list is the strating point
-each item in the list is cpmpared toithe one before to determine where it need to be placed

How well did you know this?
1
Not at all
2
3
4
5
Perfectly
5
Q

An example of a Insertion sort looks like:

A

0 1 2 3 4 5
___________
7 2 8 3 4 1<-\
2 7 8 3 4 1‎ ‎ ‎ ‎ |
2 3 7 8 4 1‎ ‎ ‎ ‎ |
2 3 4 7 8 1‎ ‎ ‎ ‎ |
1 2 3 4 7 8<-/ sorted fully in one go

How well did you know this?
1
Not at all
2
3
4
5
Perfectly
6
Q

what is the psuedocode for an Insertions sort?

A

FOR i = 0 to (LenghtOfList - 1)
‎ ‎ ‎ ‎ var j = i
‎ ‎ ‎ ‎ WHILE j > 0 AND list [j-1] > list[j]
‎ ‎ ‎ ‎ ‎ ‎ ‎ ‎ swap(list[j], list[j-1])
‎ ‎ ‎ ‎ ‎ ‎ ‎ ‎ j = j-1
‎ ‎ ‎ ‎ ENDWHILE
‎ ‎ ‎ ‎ i = i + 1
ENDFOR

How well did you know this?
1
Not at all
2
3
4
5
Perfectly
7
Q

What is a linear search?

A

When searching for an item in an array each value is examined in turn until either value is located or that end of the file/array is reached

How well did you know this?
1
Not at all
2
3
4
5
Perfectly
8
Q

Whats the problems with a linear search?

A

it is very inefficient for large arrays meaning it takes a lot of time to find a piece of data

How well did you know this?
1
Not at all
2
3
4
5
Perfectly
9
Q

What is the Pseudocode for a linear Search?

A

Position = 0

While Position < LenghtOfList AND array[position]<>searchvalue
{
‎ ‎ ‎ ‎ ‎ ‎ ‎ ‎ ‎ Position = Position + 1
}
if Position >= LenghtOfList
‎ ‎ ‎ ‎ ‎ ‎ ‎ ‎ ‎ ‎ ‎ ‎PRINT (“item not in list”)
ELSE
‎ ‎ ‎ ‎ ‎ ‎ ‎ ‎ ‎ ‎ ‎‎ PRINT(“item is at location”,pointer)

How well did you know this?
1
Not at all
2
3
4
5
Perfectly
10
Q

What is a binary sort?

A

know as divide an conquer
it works by repeatedly breaking down a problem into smaller problems
n of items being searched is halved each time making it very efficient

How well did you know this?
1
Not at all
2
3
4
5
Perfectly
11
Q

What is the pseudocode for a binary search?

A
How well did you know this?
1
Not at all
2
3
4
5
Perfectly
12
Q

What is a merge sort?

A

It was developed to handle sorting large lists
it does this via breaking the initial list down into smaller lists sorts them and then puts them back together

How well did you know this?
1
Not at all
2
3
4
5
Perfectly
13
Q

Write an example of a merge sort

A

2,45,6,9,15,12,7,8
|2|45|6|9| —– |15|12|7|8|
|2|45|–|6|9| |15|12|–|7|8|
2 45 6 9 15 12 7 8
|2|45|–|6|9| |12|15|–|7|8|
|2|6|9|45| —- |7|8|12|15|
|2|6|7|8|9|12|15|45|

How well did you know this?
1
Not at all
2
3
4
5
Perfectly