Sortarea prin inserare Descriere

10
Sortarea prin inserare Descriere Sortarea prin inserare seamană oarecum cu sortarea prin selecţie. Tabloul este impărţit imaginar în două parţi - o parte sortată şi o parte nesortată. La început, partea sortată conţine primul element al tabloului şi partea nesortată conţine restul tabloului. La fiecare pas, algoritmul ia primul element din partea nesortată şi îl inserează în locul potrivit al părţii sortate. Când partea nesortată nu mai are nici un element, algoritmul se opreşte.

description

Sortarea prin inserare Descriere - PowerPoint PPT Presentation

Transcript of Sortarea prin inserare Descriere

Page 1: Sortarea prin inserare Descriere

Sortarea prin inserareDescriere

Sortarea prin inserare seamană oarecum cu sortarea prin selecţie. Tabloul este impărţit imaginar în două parţi - o parte sortată şi o

parte nesortată. La început, partea sortată conţine primul element al tabloului şi partea nesortată conţine restul tabloului. La fiecare

pas, algoritmul ia primul element din partea nesortată şi îl inserează în locul potrivit al părţii sortate. Când partea nesortată

nu mai are nici un element, algoritmul se opreşte.

Page 2: Sortarea prin inserare Descriere

9 -5 2 12 4

ExempluSă sortăm şirul {9, -5, 2, 12, 4} folosind sortarea prin inserţie.

Page 3: Sortarea prin inserare Descriere

9 -5 2 12 4

9 > -5 , interschimbăm

Page 4: Sortarea prin inserare Descriere

-5 9 2 12 4

9 > 2, interschimbăm

Page 5: Sortarea prin inserare Descriere

-5 2 9 12 4

-5 < 2 , nu se face interschimbare

Page 6: Sortarea prin inserare Descriere

-5 2 9 12 4

9 < 12 nu se face interschimbare

Page 7: Sortarea prin inserare Descriere

-5 2 9 12 4

4 va fi inserat, 4 < 12, interschimbăm

Page 8: Sortarea prin inserare Descriere

-5 2 9 4 12

4 < 9 , interschimbăm

Page 9: Sortarea prin inserare Descriere

-5 2 4 9 12

SORTAT

Page 10: Sortarea prin inserare Descriere

Algoritm descris în pseudocod

pentru i ← 1,n executăj← i ; cât timp j>0 si v[j-1]>v[j] execută

aux ← v[j] ;v[j] ← v[j-1] ;v[j-1] ← aux ;j ← j-1 ;