Professional Documents
Culture Documents
01 Nizovi Liste
01 Nizovi Liste
[IR2ASP]
KOLOKVIJUM
4
Zadatak 1
SUM1 SUM2
sum=0 sum=0
for i=1 to 32 do for j=1 to 16 do
for j=1 to 16 do for i=1 to 32 do
sum=sum+ M[i,j] sum=sum+ M[i,j]
end_for end_for
end_for end_for
5
Rešenje
Zadatak ilustruje posledice razlike u redosledu pristupanja
elementima matrice, uzimajući u obzir hardversku
realizaciju računara.
Dva najčešća načina smeštanja matrica u memoriju
računara:
– Po vrstama
– Po kolonama
Primer:
po vrstama po kolonama
1 5 9 13 1 5 9 13
2 6 10 14 2 6 10 14
3 7 11 15 3 7 11 15
4 8 12 16 4 8 12 16
adresa a a+1 a+2 a+3 a+4 a+5 a a+1 a+2 a+3 a+4 a+5
1 5 9 13 2 6 ... 1 2 3 4 5 6 ... 6
Rešenje
7
Rešenje
10
Zadatak 2
Prikazati vektorsku prezentaciju retke matrice sa slike:
a) sa jednim vektorom zapisa od po tri polja,
b) sa tri posebna vektora.
0 0 0 0 0 0
0
0 0 0 0 0 0
4
0 0 5 0 11 0
0
X
0 0 0
0 0 0 0
9 0 8 10 0 0
0
0 0 15 0 0 0 0
11
Rešenje a)
0 0 0 0 0 0 0 R K V
0 0 4 0 0 0 0
2 3 4
3 4 5
3 6 11
0 0 0 5 0 11 0 5 1 9
X 5 4 8
0 0 0 0 0 0 0
5 5 10
9 0 0 8 10 0 0 6 3 15
0 0 15 0 0 0 0
12
Rešenje b)
0 0 0 0 0 00 R C V
0 0 4 0 0 0 0 1 0 1 3 4
2 1 2 4 5
0 0 0 5 0 11 0 3 2 3 6 11
X 4 0 4 1 9
0 0 0 0 0 0 0 5 4 5 4 8
9 0 0 8 10 0 0 6 7 6 5 10
7 3 15
0 0 15 0 0 0 0
13
Zadatak 3
14
Rešenje
DIMENSION K(3,4)
DO I=1,3 2 3 4 5
DO J=1,4
K(I,J)=I+J
K 3 4 5 6
ENDDO
ENDDO 4 5 6 7
CALL MISSMATCH(K)
PRINT *, ((K(I,J), J=1,4),
I=1,3)
END
15
Rešenje
SUBROUTINE MISSMATCH(K)
DIMENSION K(1,1)
K(2,3)=0
RETURN
END 2 3 4 5
K 3 4 5 6
4 5 6 7
Adresa elementa:
Ai,j = Al1,l2 + ((j – l2)(u1 – l1 + 1) + i – l1)s
i=2, j=3,l2=1,l1=1,u1=1
A2,3=A1,1+((3-1)(1-1+1)+2-1)s
16
Zadatak 4
i x x x
Broj elemenata
x x u koloni j
i 1
x pre traženog elementa:
17
Zadatak 5
a32 a33 a34 a11 a12 a21 a22 a23 a32 a33 ...
glava
glava
20
Rešenje
5
INVERT(list) čvor l čvor m čvor n
p = list
q = nil
2 1 1 4
while (p nil)
3
do
r=q
q=p
p = next(p)
r q p
next(q) = r
end_while
list = q
21
Zadatak 2
Realizovati operaciju CONCATENATE(list1,list2) koja
nadovezuje listu na koju pokazuje list2 na listu ukazanu sa
list1:
• ako su liste jednostruko ulančane,
• sa kružno ulančanim listama.
22
Rešenje a)
CONCATENATE(list1, list2) p
p = next(p)
end_while
next(p) = list2
23
Rešenje b)
Spoljni pokazivač (list1 i list2) pokazuje p list1
na poslednji element liste !!
1
CONCATENATE-C(list1, list2)
if (list1 = nil) then čvor 1 čvor 2 čvor 3
3
list1 = list2
return
list2
else if (list 2 = nil) then 2
return čvor 1
4
čvor 2 čvor 3 čvor 4
end_if
p = next(list1)
next(list1) = next(list2)
next(list2) = p
list1 = list2
24
Zadatak 3
Napisati operacije inicijalizacije liste slobodnih ulaza,
alokacije i dealokacije čvora
u slučaju vektorske implementacije ulančanih lista
2 3 4 5 6 7 ... 0
indeks 1 2 3 4 5 6 n
25
Rešenje
INIT
avail = 1
for i = 1 to n – 1 do
L[i].next = i +1
end_for
L[n].next = 0
GETNODE
if (avail = 0) then
ERROR(Nema prostora)
end_if
p = avail
avail = L[avail].next
return p
FREENODE(p)
L[p].next = avail
avail = p
26
Zadatak 4
Neka su dva skupa predstavljena uređenim jednostruko
ulančanim listama sa zaglavljima na koja ukazuju
pokazivači A i B. Realizovati funkciju koja vraća pokazivač
na zaglavlje liste koja predstavlja presek ova dva skupa.
glava
27
Rešenje
INTERSECTION(A, B)
r = c = GETNODE Rezultujuća lista obavezno mora da bude
p = next(A) istog tipa kao i liste A i B (sa zaglavljem)
q = next(B)
while (p nil) and (q nil) do
if (info(p) = info(q)) then
next(c) = GETNODE
c = next(c)
info(c) = info(p)
p = next(p) r c
q = next(q)
else if (info(p) < info(q)) then
p = next(p)
else
q = next(q) 2 4 6
end_if
end_if zaglavlje čvor 1 čvor 2 čvor 3
end_while
nil
return r 1 3 5
28
Zadatak 5
29
Rešenje
POLY-ADD(p1, p2)
r = GETNODE
next(r) = r
exp(r) = -1
t=r
p = next(p1)
q = next(p2)
while (p p1) or (q p2) do
if (exp(p) = exp(q)) then
if (c(p) + c(q) 0) then
INSERT-AFTER(t, c(p) + c(q), exp(p))
t = next(t)
end_if
p = next(p)
q = next(q)
else if (exp(p) < exp(q)) then
INSERT-AFTER(t, c(q), exp(q))
q = next(q)
t = next(t)
else
INSERT-AFTER(t, c(p), exp(p))
p = next(p)
t = next(t)
end_if
end_while
return r
30
Zadatak za vežbu
Data je kružna lista sa n elemenata.
Napisati algoritam koji izbacuje svaki osmi član liste.
Uraditi zadatak za jednostruko i za dvostruko ulančane liste.
31