Sortering Flashcards
Hva er ideen til Bubble sort?
Vi løper gjennom arrayet og “retter opp” feil, helt til det ikke er noen flere feil å rette opp.
- Løp over hvert par av etterfølgende elementer i arraayet.
- Bytte om rekkefølgen for paret dersom det ikke er ordnet.
- Gå til 1. dersom det forekom minst et bytte.
For hver runde drar vi med oss det neste største elementet til bunnen.
Hva er ideen til Selection sort?
Vi finner det minste elementet i resten og plasserer dette først.
- La i være 0
- Finn hvor det minste elementet fra i og utover ligger
- Bytt ut elemntet på plass i med det minste (hvis nødvendig)
- Øk i og gå til 2. frem til i når størrelsen av arrayet.
Hva er ideen til Insertion sort?
Vi plasserer alle elementene sortert inn i en liste, vi lar alt til venster for en posisjon ‘i’ være sortert.
- La i være 1
- Dra det i-te elementet mot venstre så lenge det er mindre enn elementet før seg (som ved sortert innsetting)
- Øk i og gå til 2. frem til i når størrelsen av arrayet.
(Slik en ville sortert kort)
Når vi drar i-te elementet mot venstre, så bytter vi plass med element på plass forran seg i arrayet, og dette gjør vi helt til vi har flyttet elementet til indeks 0 eller elementet på plassen forran er mindre eller lik elementet vi drar mot venstre.
Hva er ideen til Heapsort?
Vi bygger en max-heap og popper elementer av heapen.
- Siden heap kan implementeres som et array, kan vi gjøre om input arrayet til en heap.
- Gjør arrayet til en max-heap
- La i være n-1 der n er størrelsen på arrayet
- Pop fra max-heapen og plasser elementet på plass i
- Senk i og gå til 3. frem til i blir 0
Vi bruker en prosedyre BubbleDown for å lage max-heapen.
Hva er ideen til Merge sort?
Vi splitter arrayet i to ca. like store deler, deretter:
- sorterer de to mindre arrayene
- flette (merge) de to sortere arrayene
- La n angi størrelsen på arrayet A
- hvis n <= 1, returner A
- la i = n//2
- splitt arrayet i to deler A[0..i] og A[i…n-1]
- avend merge sort rekursivt på de to arrayene
- flett sammen de to arrayene sortert.
Hva er ideen til Quicksort?
Vi velger et element, så
- samle alt som er mindre enn elementet til venstre for det
- samle alt som er størrre enn elementet til høyre for det
- gjør dette rekursivt
Hva er ideen til Bucket sort?
Vi lager N bøtter, hvor bøtte svarer til en kategori eller sort og kategoriene er ordnet.
Hvert element vi sorterer har en kategori, som tilsvarer en nøkkel.
Vi plasserer så vært element i riktig bøtte basert på nøkkelen.
Så løper vi gjennom hver bøtte og plasserer elementene tilbake i arrayet.
Hva er ideen til Radix sort?
Radix sort er en suksessiv anvendelse av bucket sort.
Altså om det benyttes flere bucket sort etter hverandre, hvor vi benytter prinsippet om at bucket sort er stabil.
For eksempel sortering av kort med to bucket soerteringer, hvor vi først sorterer på verdi og så sorterer på sort (hjerter, ruter, etc).
Hva betyr det at en sorteringsalgoritme er stabil?
Når en sorteringsalgoritme er stabil så er det slik at
- for alle elementer x,y med samme nøkkel k
- hvis x forekommer før y før sorteringen
- så forekommer x før y etter sorteringen
For eksempel bucket sort av kort etter kun verdi, om ruter 7 kommer før kløver 7 før sorteringen, så kommer ruter 7 også før kløver 7 etter sorteringen
- (7 er altså bøtte kategorien og nøkkelen k)
Hvordan kan vi implementere Bubble sort?
Benytter dobbel for-loop i/j:
- Den indre loopen går til og med n - i - 2 (hvor i er den ytre loopen) fordi vi drar med oss det i’nde største elementet til bunn hver runde i den ytre loopen.
- Altså vet vi at elementene etter n-i-2 allerede er sortert riktig.
for i=0 to n-2 do
- for j=0 to n-i-2
- — if A[j] > A[j+1] then
- —– swap(j, j+1)
Hvordan kan vi implementere Selection sort?
Benytter dobbel for-loop i/j:
- La i være 0
- Finn det minste elementet fra j=i+1 og utover ligger.
- Bytt ut elemntet på plass i med det minste (hvis nødvendig)
- Øk i og gå til 2. frem til i når størrelsen av arrayet.
for i=0 to n-1 do
- k=i
- for j=i+1 to n-1 do
- — if A[j] < A[k] then
- ——- k=j
- end
- if i != k then
- — swap(i, k)
Hvordan kan vi implmenetere Insertion sort?
Benytter en for-loop og en while-loop:
- La i være 1
- Dra det i-te elementet mot venstre som ved sortert innsetting
- Øk i og gå til 2. frem til i når størrelsen av arrayet.
Vi drar altså det i-te elementet plass for plass mot venstre (indeks 0) så lenge det i-te elementet er mindre enn det som kommer på plass A[j-1]
for i=1 to n-1 do
- j = i
- while j > 0 and A[j-1] > A[j] do
- — swap(j-1, j)
- — j = j-1
Hvordan kan vi implementere Heapsort?
- Gjør arrayet til en max-heap
- La i være n-1 der n er størrelsen på arrayet
- Pop fra max-heapen og plasser elementet på plass i
- Senk i og gå til 3. frem til i blir 0
Vi bruker en prosedyre BubbleDown for å lage max-heapen.
BuildMaxHeap(A, n)
for i=n/2 down to 0 do
– BubbleDown(A, i, n)
HeapSort(A)
- BuildMaxHeap(A, n)
- for i = n-1 down to 0 do
- — swap(0, i)
- — BubbleDown(A, 0, i)
Vi bygger en max-heap.
Så for hver loop, før vi krymper arrayet vi jobber med (for loop) flytter vi det største elementet (som er på plass 0 i en max-heap) ned til bunnen som er plass i.
Når vi har flyttet dette største elementet kaller vi BubbleDown med n=i så vi ikke bobbler hele veien ned og drar det største elementet til toppen igjen.
Hvordan kan vi implementere Quicksort?
Velg pivot-element ‘i’
- søk fra venstre mot høyre etter et element som er større enn A[i]
- søk fra høyre mot venstre etter et element som er mindre enn A[i]
- bytt plass på disse, og søk etter nye som kan byttes
- avslutt når høyre og venstre søkene krysser.
Fortsett rekursivt på alle som er hhv. til venstre og høyre for pivot.
Prosedyren Partion
- Flytter elementer som er hhv. mindre og større til venstre og høyre enn en gitt index som returneres.
Quicksort(A, low, high)
- if low >= high then
- — return A
- p = Partition(A, low, high)
- Quicksort(A, low, p-1)
- Quicksort(A, p+1, high)
- return A
Hvordan kan vi implementere Quicksort?
Velg pivot-element ‘i’
- søk fra venstre mot høyre etter et element som er større enn A[i]
- søk fra høyre mot venstre etter et element som er mindre enn A[i]
- bytt plass på disse, og søk etter nye som kan byttes
- avslutt når høyre og venstre søkene krysser.
Fortsett rekursivt på alle som er hhv. til venstre og høyre for pivot.
Prosedyren Partion
- Flytter elementer som er hhv. mindre og større til venstre og høyre enn en gitt index som returneres.
Quicksort(A, low, high)
- if low >= high then
- — return A
- p = Partition(A, low, high) // returnerer pivot indeksen
- Quicksort(A, low, p-1)
- Quicksort(A, p+1, high)
- return A