Documente Academic
Documente Profesional
Documente Cultură
• Ce este un algoritm ?
a
…..
• Ce este un algoritm ?
algorism algorithm
• Metoda de rezolvare
• Imparte a la b și retine
restul
• Imparte b la rest și
reține noul rest
• continuă impărțirile
până se ajunge la un
rest nul
• Ultimul rest nenul
reprezintă rezultatul
• Ce este un algoritm ?
• Generalitate
• Finitudine
• Neambiguitate
• Eficienta
Exemplu:
Sa considerăm problema ordonării (sortării) crescătoare a unui
șir de valori numerice.
De exemplu:
(2,1,4,3,5) (1,2,3,4,5)
date intrare rezultat
Metoda: Descriere:
…..
Pas 4: 1 2 3 4 5 - Continuă procesul până la ultimele
două elemente din secvență
• Generalitate
• Finitudine
• Neambiguitate
• Eficiență
Exemplu
Pas1: Asignează 1 lui x;
Pas2: Adaugă 2 la x;
Pas3: Dacă x=10 atunci STOP;
altfel se reia de la Pasul 2
• Finitudine
• Neambiguitate
• Eficiență
Exemplu:
10
10
8
8
6
6
4
4
2 2
0 0
0 20 40 60 80 100 0 20 40 60 80 100
• Finitudine
• Neambiguitate
• Eficiență
A doua abordare:
se parcurge cartea de telefon în ordinea alfabetică a numelor
persoanelor și pentru fiecare persoană se verifică dacă numărul
de telefon conține cifre distincte
Notăm cu:
– m = numărul de cifre ale numărului (ex: m=10)
– n = numărul de înregistrări în cartea de telefon
m!* m*log2n
m! m log2n nm
Exemplu: m=10
n= 304.467 (populația Timișoarei în 2011)
Aproximativ
6.6* 108 3*106 operații
m! m log2n nm
Exemplu: m=10
n= 304.467 (populația Timișoarei în 2011)
Aproximativ
6.6* 108 3*106 operații
• Ce este un algoritm ?
∑ i = 1 + 2 + ... + n
i =1
?
Caracteristici:
– nume
– valoare
• constantă (aceeași valoare pe parcursul executiei algoritmului)
• variabilă (valoarea se schimbă pe parcursul execuției
algoritmului)
– tip
• simplu (ex: numere, caractere, valori de adevăr …)
• structurat (ex: tablouri)
(1,1) (1,2)
• Matrici
– Tablouri multidimensionale 1 0 1 0
0 1 0 1
Algoritmica - Curs 1 (2014)
(2,1) (2,2) 41
Cum pot fi specificate datele ?
• Date simple:
Bi-dimensionale
<tip element> <nume>[ m1..m2, n1..n2]
(ex: INT A[1..m,1..n])
– Bidimensionale
A[i,j] - i este indice de linie, j este indice de coloană
1 n
1
j1 j2
i1
1 i1 i2 n i2
m
Algoritmica - Curs 1 (2014) 45
Cuprins
• Rezolvarea problemelor
• Ce este un algoritm ?
Tipuri de instrucțiuni:
– Simple
• Atribuire (atribuie o valoare unei variabile)
• Transfer (preia date de intrare; afișează rezultate)
• Control (specifică care este următorul pas care trebuie
executat)
– Structurate ….
• Logici:
or sau | (disjuncție), and sau &
(conjuncție), not (negație)
Algoritmica - Curs 1 (2014) 49
Intrare/iesire
• Scop:
– Preia date de intrare
– Furnizează rezultate
• Descriere:
read v1,v2,…
write e1,e2,…
Intrare Iesire
(citire) Variabile (scriere)
utilizator algoritm utilizator
Read (program) Write
(input) Algoritmica - Curs 1 (2014) (print) 50
Intrare/iesire
• Scop:
– Preia date de intrare
– Furnizează rezultate
• Descriere:
read v1,v2,…
write e1,e2,…
Intrare Iesire
(citire) Variabile (scriere)
utilizator algoritm utilizator
Read (program) Write
(input) Algoritmica - Curs 1 (2014) (print) 51
Intrare/iesire
• Exemplu (Python)
– Instrucțiune de decizie
(condițională)
Adevarat
conditie
Fals • Varianta simplificată (pseudocod):
n=input("n=")
if n%2==0:
print "Numar par"
x=input("x=")
else:
if x>0:
print "Numar
s=1
impar"
elif x<0:
s=-1
else:
s=0
print "sgn(",x,")=",s
instructiune ∑ i = 1 + 2 + ... + n
i =1
Adevarat
v=v1
while v<=v2 do
for v=v1,v2,pas do
<instructiune>
<instructiune>
v=v+pas
endfor
endwhile
Algoritmica - Curs 1 (2014) 61
FOR - exemplu
v=v1
n
v <= v2
Fals
Urmatoarea ∑ i = 1 + 2 + ... + n
i =1
Adevarat instructiune
<instructiune>
S:=0 // pregateste variabila in
v=v+pas //care se va colecta rezultatul
for i=1,n do
S=S+i // adauga termenul curent la S
for v=v1,v2,pas do endfor
<instructiune>
endfor
<instructiune> ∑ i = 1 + 2 + ... + n
i =1
<conditie>
S=0 S=0
Adevarat i=1 i=0
repeat repeat
Instructiune S=S+i i=i+1
urmatoare i=i+1 S=S+i
repeat until i>n until i>=n
<instructiune>
until <conditie>
REPEAT … UNTIL
• Subalgoritmi / functii
• Diferite exemple
http://goo.gl/sUR1XQ