Diskuze: Jaká je časová komplexita tohoto rekurzivního kódu?
Zobrazeno 4 zpráv z 4.
//= Settings::TRACKING_CODE_B ?> //= Settings::TRACKING_CODE ?>
Wow, s takovým kódem jsem se ještě nesetkal
Nejsem na to odborník, tak to ber s rezervou:
V nejlepším případě (řešení se najde a neproběhne rekurze) bude
časová složitost n6 (6 zanořených cyklů o délce n, zbytek je
zanedbatelný). Průměrnou složitost těžko posoudit, záleží na podmínce
pro nalezení řešení. Záleží na podmínce pro nalezené řešení a zda je
výsledek předpověditelný, v nejhorším případě teoreticky může běžet
kód do nekonečna (tedy pokud se nezaplní stack v případě že n je tak
malé, že to stihne).
V jakých řádech se N obvykle pohybuje? Zkoušel jsi ten kód spouštět?
Pokud dělá rekurze problém se zjištěním časové složitosti, můžeš si to přepsat do podoby bez ní (místo rekurzivního předávání argumentů budeš hodnoty ukládat do nějaké proměnné).
Podle tvyho popisu bych rekl typicky (a minimalne) N6, nejhorsi N8, jestli jsem dobre pochopil tvuj popis - ze rekurze se muze v rekurzivni metode vnorovat maximalne o jednu uroven, protoze tam se uz vzdycky najde reseni.
Rekurze se muze vyskytnout az (predpokladam, ze pole ma vetsi velikost, u pole 1x1 to rekurzivne nepujde samozrejme vubec)
N2 - (pocet vnoreni 2. metody * 10) v nejhorsim pripade, v prumernem se spusti dle zadani asi pro N=10, 3krat. Asi si to prepisu mimo rekurzi, jak rikal David Dostal, asi to pak pujde nejak lepe urcit.
Dekuji vsem
Zobrazeno 4 zpráv z 4.