Časovna zahtevnost
Časovna zahtevnost je podatek o tem, koliko časa se bo program (oziroma algoritem) pri danih vhodnih podatkih izvajal, preden bo vrnil rešitev. Čas običajno merimo v osnovnih operacijah stroja, ki program izvaja. Časovno zahtevnost podamo kot funkcijo velikosti vhodnih podatkov (npr. velikost tabele). Poznamo tri vrste časovne zahtevnosti:
- fB - najboljša možnost (best case) ali spodnja meja zahtevnosti (primer že urejene tabele)
- fW - najslabša možnost (worst case) ali zgornja meja zahtevnosti (primer nasprotno urejene tabele)
- fE - pričakovana zahtevnost (expected case) pri povprečnih podatkih
Ker je običajno natančno število operacij težko ali nemogoče določiti, uporabimo O-notacijo, ki označuje red rasti problema. Če velikost vhoda označimo z n, c pa je neka konstanta, potem imamo naslednje zahtevnosti, od najugodnejše do najneugodnejše:
Notacija | zahtevnost |
---|---|
konstantna | |
logaritemska | |
linearna | |
vmesna | |
kvadratna | |
, | polinomska |
eksponentna |
Zunanje povezave
- Časovna zahtevnost Arhivirano 2007-05-09 na Wayback Machine. na MaFiRa