=== Counting sort(sortiranje prebrojavanjem) ===
Ovaj, takođe stabilan, algoritam se koristi za sortiranje lista kod kojih je ključ po kome\\
se sortira prirodan, odnosno ceo broj (mada se ideja može iskoristiti za sve vrste lista\\
kod kojih je ključ iz nekog konačnog opsega). Za njegov rad je potrebno određivanje\\
maksimalne vrednosti ključa (ako su prirodni brojevi pitanju). Ideja je da se za formiranje\\
izlazne liste koristi pomoćna lista, čiji su indeksi vrednosti u intervalu od 0 do\\
maksimalne vrednosti ključa. Ta lista ima zadatak da prebroji pojavljivanja svih brojeva\\
iz skupa „mogućih” vrednosti, i dobija se jednim prolazom kroz ulaznu listu. Na osnovu\\
pomoćne liste algoritam rekonstruiše sortiranu izlaznu listu.\\
Kompleksnost ovog algoritma je //O(n+k)// , gde je k maksimalna vrednost\\
ključa. Očigledno, **k** bi trebao da bude osetno manji u odnosu na **n**, da ne bi imao bitnog\\
uticaja na brzinu rada.\\
Primer algoritama //(program counting_sort1;)// koji sortira niz prirodnih brojeva, pri čemu\\
brojevi imaju vrednosti do **k**, a ima ih **n**. Niz **a** je niz koji se zadaje na ulazu, onaj niz koji\\
treba sortirati. U nizu **b** se pamti sortiran niz **a**, a **c[i]** je broj pojavljivanja broja **i** u nizu **a** u\\
drugoj petlji, a u trećoj petlji **c[i]** je poslednje mesto u nizu gde se pojavljuje broj **i**.\\
Druga for petlja inicijalizuje niz c tako da vrednost svih njegovih članova\\
bude 0. Treća ''for'' petlja formira niz **c**, odnosno broji koliko puta se svaki član niza **a[i]**\\
pojavljuje **i** tu vrednost pamti na **a[i]**-tom mestu u nizu **c**. Četvrta ''for'' petlja sabira u **i**-ti\\
član niza **c** sve one članove pre njega, čime se postiže da **c[i]** sada pokazuje na kojem će se\\
mestu poslednji put pojaviti **i**. Peta ''for'' petlja formira niz **b**, tako što se, najpre, na **c[i]**-to\\
mesto u niz **b** postavi taj broj **a[i]**, pa pošto je ono sada popunjeno, **c[i]** se smanjuje za\\
jedan. Postupak se ponavlja dok se ne formira ceo niz **b**.\\
Primer:Ako se unese niz **a**: //1,4,5,1,4,2,1,// **b** i **c** će se kroz program menjati na sledeći\\
način:\\
Posle treće petlje:\\
\\
**A 1 4 5 1 4 2 1** || C 3 1 0 2 1\\
\\
Posle četvrte petlje:\\
\\
C 3 4 4 6 7\\
\\
Posle pete petlje:\\
\\
|B|X|X|1|X|X|X|X|
|B|X|X|1|2|X|X|X|
|B|X|X|1|2|X|4|X|
|B|X|1|1|2|X|4|X|
|B|X|1|1|2|X|4|5|
|B|X|1|1|2|4|4|5|
|**B**|**1**|**1**|**1**|**2**|**4**|**4**|**5**|
Poboljšana verzija //(program counting_sort2;)// određuje **min** i **max** niza, prebrojava\\
pojavljivanje članova niza **a**, što se pamti na nizu **o**, prolaskom **i**, čiji broj\\
pojavljivanja **o[i]**, od **min** do **max** formira se sortiran niz **a**.\\
\\
program counting_sort1;
var a,b,c:array [1..100] of integer;
i,j,k,n:integer;
begin read(n,k);
for i:=1 to n do read(a[i]);
for i:=1 to k do c[i]:=0;
for j:=1 to n do c[a[j]]:=c[a[j]]+1;
for i:=2 to k do c[i]:=c[i]+c[i-1];
for j:=n downto 1 do
begin
b[c[a[j]]]:=a[j]; c[a[j]]:=c[a[j]]-1;
end;
for i:=1 to n do write(b[i]:4);
end.
\\
/* program counting_sort1;*/
#include
main()
{int i,j,k,n;
int a[100],b[100],c[100];
scanf("%d%d",&n,&k);
for (i=1;i<=n;i++) scanf("%d",&a[i]);
for (i=1;i<=k;i++) c[i]=0;
for (j=1;j<=n;j++) c[a[j]]=c[a[j]]+1;
for (i=2;i<=k;i++) c[i]=c[i]+c[i-1];
for (j=n;j>=1;j--)
{ b[c[a[j]]]=a[j]; c[a[j]]=c[a[j]]-1;}
for (i=1;i<=n;i++) printf("%d ",b[i]);
}
\\
program counting_sort2;
var i,j,n,min,max,k:integer;
a:array[1..200] of integer;
o:array[1..900] of integer;
begin
readln(n);
min:=maxint; max:=0; k:=0;
fillchar(o,sizeof(o),0);
for i:=1 to n do begin
readln(a[i]);
o[a[i]]:=o[a[i]]+1;
if a[i]>max then max:=a[i];
if a[i]0 then
for j:=1 to o[i] do
begin
k:=k+1; a[k]:=i;
end; {k=n}
for i:=1 to n do write(a[i],' ');
end.
\\
/* program counting_sort2;*/
#include
main()
{
int i,j,n,min,max,k;
int a[200],o[900];
scanf("%d",&n);
min=32700;max=0;k=0;
for (j=0;j<=900;j++) o[j]=0;
for(i=1;i<=n;i++)
{
scanf("%d",&a[i]); o[a[i]]+=1;
if (a[i]>max) max=a[i];
if (a[i]
\\
----
[[programiranje-sortiranje|Back]] Contact: