Vydělávej až 160.000 Kč měsíčně! Akreditované rekvalifikační kurzy s garancí práce od 0 Kč. Více informací.
Hledáme nové posily do ITnetwork týmu. Podívej se na volné pozice a přidej se do nejagilnější firmy na trhu - Více informací.

Lekce 5 - Dynamické programování

V minulé lekci, Časová složitost algoritmů a jejich odhad složitosti, jsme se blíže podívali na časovou složitost algoritmů. Naučili jsme se odhadnout jejich složitost.

V dnešním tutoriálu o teorii algoritmů si představíme dynamické programování, které využívá již dříve spočítané výsledky. Jedná se o počítání výsledků, kdy mezivýsledky vznikají průběžně.

Dynamické programování si ukážeme nejen praktickém příkladu výpočtu Fibonacciho čísla, ale zmíníme si i jeho další využití.

Výpočet Fibonacciho čísla v dynamickém programování

Nejznámějším příkladem pro dynamické programování je výpočet n-tého Fibonacciho čísla.

Výpočet si ukážeme dvěma způsoby, a to pomocí:

  • rekurentního výpočtu,
  • uložení výsledků do pole,
  • uložení výsledků do třech proměnných.

Rekurentní výpočet

Matematický rekurentní vzorec vypadá takto: fib(0) = 1, fib(1) = 1 a fib(n) = fib(n-1) + fib(n-2). Číselná řada začíná touto sekvencí čísel: 1, 1, 2, 3, 5, 8, 13, 21, 34, 55. Tento rekurentní vzorec je správně, ale je velmi neefektivní. Vyžaduje totiž mnoho opakování výpočtu stejných hodnot, což vede k mnoha zbytečným a opakovaným výpočtům.

Z obrázku níže je zřejmé, že například fib(2) se počítá úplně zbytečně několikrát:


 

...konec náhledu článku...
Pokračuj dál

Znalosti v hodnotě stovek tisíc získáš za pár korun

Došel jsi až sem a to je super! Věříme, že ti první lekce ukázaly něco nového a užitečného.
Chceš v kurzu pokračovat? Přejdi do prémiové sekce.

Koupit tento kurz

Koupit všechny aktuálně dostupné lekce s funkcí odevzdávání úloh a certifikátem za pouhých 200 Kč
Aktuální stav konta 0 Kč
Koupí tohoto balíčku získáš přístup ke všem 7 článkům (6 lekcí, test) tohoto kurzu.

Obsah článku spadá pod licenci Premium, koupí článku souhlasíš se smluvními podmínkami.

Co od nás v dalších lekcích dostaneš?
  • Neomezený a trvalý přístup k jednotlivým lekcím.
  • Kvalitní znalosti v oblasti IT.
  • Dovednosti, které ti pomohou získat vysněnou a dobře placenou práci.

Popis článku

Požadovaný článek má následující obsah:

V tutoriálu o teorii algoritmů si představíme dynamické programování, které využívá již dříve spočítané výsledky.

Kredity získáš, když podpoříš naši síť. To můžeš udělat buď zasláním symbolické částky na podporu provozu nebo přidáním obsahu na síť.

Článek pro vás napsal Ondřej Michálek
Avatar
Autor se věnuje teoretické informatice. Ve svých volných chvílích nepohrdne šálkem dobrého čaje, kaligrafickým brkem a foukací harmonice.
Aktivity