ALG 04. Zásobník Fronta Operace Enqueue, Dequeue, Front, Empty... Cyklická implementace fronty. Průchod stromem do šířky
|
|
- Hynek Havel
- před 6 lety
- Počet zobrazení:
Transkript
1 LG 04 Zásobník Fronta Operace nqueue, equeue, Front, mpty... yklická implementace fronty Průchod stromem do šířky Grafy průchod grafem do šířky průchod grafem do hloubky Ořezávání a heuristiky 1
2 Zásobník / stack Prvky se před zpracováním vkládají na vrchol zásobníku Vrchol / top Prvky se odebírají z vrcholu zásobníku a pak se zpracovávají. Operace Vlož na vrchol Push Odeber z vrcholu Pop Čti začátek Top Je prázdný? mpty
3 Fronta / queue Čelo / front Konec / tail Prvky se před zpracováním vkládají na konec fronty. Prvky se odebírají z čela fronty a pak se zpracovávají. Operace Vlož na konec nqueue / InsertLast / Push... Odeber ze začátku equeue / delfront / Pop... Čti začátek Front / Peek... Je prázdná? mpty 3
4 Fronta Čelo Konec Jednoduchý příklad života fronty Prázdná Vlož(4) Vlož(11) Vlož(90) Odeber() Vlož(43) Odeber() Odeber() Vlož(79)
5 yklická implementace fronty polem Čelo Konec Prázdná fronta v poli pevné délky Vlož 4, 11, 90, 43, Odeber, odeber, odeber Vlož 10, Odeber, odeber Vlož 55,, Odeber, odeber
6 yklická implementace fronty polem Index/ukazatel konce fronty ukazuje na první volnou pozici za posledním prvkem fronty. Index/ukazatel čela fronty ukazuje na první obsazenou pozici. Pokud oba ukazují tamtéž, fronta je prázdná. class Queue { Node q []; int size; int front; int tail; Queue( int qsize ){ size = qsize; q = new Node[size]; front = 0; tail = 0; } boolean mpty() { return ( tail==front ); } void nqueue( Node node ){ if( (tail+1 == front) (tail-front == size-1) )... // queue full, fix it } q[t++] = node; if( tail==size ) tail = 0; Node equeue() { Node n = q[front++]; if( front == size ) front = 0; return n; } } // end of Queue 6
7 Průchod stromem do šířky Strom s naznačeným směrem průchodu Pořadí uzlů Struktura stromu ani rekurzivní přístup tento průchod nepodporují. 7
8 Průchod stromem do šířky Inicializace 30 Vytvoř prázdnou frontu o fronty vlož kořen stromu Čelo Konec Hlavní cyklus okud není fronta prázdná, opakuj: 1. Odeber první uzel z fronty a zpracuj ho.. o fronty vlož jeho potomky, pokud existují. 8
9 Průchod stromem do šířky x x = Odeber(), tisk (x.key) Vlož(x.left), vlož(x.right). *) x x = Odeber(), tisk(x.key). 71 Vlož(x.left), vlož(x.right). *) *) pokud existuje
10 Průchod stromem do šířky 30 x 1. x = Odeber(), tisk (x.key) Vlož(x.left), vlož(x.right). *) x x = Odeber(), tisk(x.key). 5 8 *) pokud existuje Vlož(x.left), vlož(x.right). *)
11 Průchod stromem do šířky x 1. x = Odeber(), tisk (x.key) Vlož(x.left), vlož(x.right). *) x x = Odeber(), tisk(x.key) *) pokud existuje Vlož(x.left), vlož(x.right). *)
12 Průchod stromem do šířky x 1. x = Odeber(), tisk (x.key) Vlož(x.left), vlož(x.right). *) x x = Odeber(), tisk(x.key) *) pokud existuje Vlož(x.left), vlož(x.right). *)
13 Průchod stromem do šířky x 1. x = Odeber(), tisk (x.key) Vlož(x.left), vlož(x.right). *) x x = Odeber(), tisk(x.key) *) pokud existuje Vlož(x.left), vlož(x.right). *)
14 Průchod stromem do šířky x 1. x = Odeber(), tisk (x.key) Vlož(x.left), vlož(x.right). *) x = Odeber(), tisk(x.key). 30 x Vlož(x.left), vlož(x.right). *) *) pokud existuje
15 Průchod stromem do šířky 1. x = Odeber(), tisk (x.key). 30 x Vlož(x.left), vlož(x.right). *) *) pokud existuje Fronta je prázdná, průchod stromem končí. V neprázdné frontě jsou vždy právě -- některé (třeba všechny) uzly jednoho patra -- a všichni potomci těch uzlů tohoto patra, které už nejsou ve frontě. Někdy jsou ve frontě přesně všechny uzly jednoho patra. Viz výše. 15
16 Průchod stromem do šířky void traversetreereadthfirst( Node node ) { if( node == null ) return; Queue q = new Queue(); // init q.nqueue( node ); // root into queue while(!q.mpty() ) { node = q.equeue(); print( node.key ); // process node if( node.left!= null ) q.nqueue( node.left ); if( node.right!= null ) q.nqueue( node.right ); } } 16
17 Grafy graf je uspořádaná dvojice a b o množiny vrcholů V a o množiny hran G = (V, ) příklad: V = {a, b, c, d, e} = {{a,b},{b,e},{b,c}, {c,e},{e,d}} d c e 17
18 Grafy - orientovanost neorientovaný graf o hrana je neuspořádaná dvojice vrcholů = {{a,b},{b,e},{b,c}, {c,e},{e,d}} orientovaný graf o hrana je uspořádaná dvojice vrcholů = {{a,b},{b,e},{b,c}, {c,e},{e,d}} a b a b c c d e d e 18
19 Grafy matice sousednosti Nechť G = (V, ) je graf s n vrcholy Označme vrcholy v 1,, v n (v nějakém libovolném pořadí) Matice sousednosti grafu G je čtvercová matice ( a ) n G i, j i, j 1 definovaná předpisem a i, j 1 pro{ v, v 0 jinak i j } 19
20 Grafy matice sousednosti pro orientovany graf a b c d e a b a b c d e d c e 0
21 Grafy seznam sousedů Nechť G = (V, ) je (ne)orientovaný graf s n vrcholy Označme vrcholy v 1,, v n (v nějakém libovolném pořadí) Seznam sousedů grafu G je pole P ukazatelů velikosti n kde P[i] ukazuje na spojový seznam vrcholů, se kterými je vrchol v i spojen hranou a b b a c e a b c d e b e c e b d d c e 1
22 Průchod grafem do hloubky Matice sousednosti Spojová reprezentace F G H H G F G G H G F F G H
23 Průchod grafem do hloubky 1/- F /- 3/- G 4/- H 1/- Zásobník Zásobník 1/- /- 1/- F /- 3/- G H Zásobník G Zásobník G H G G H 3
24 Průchod grafem do hloubky 1/- /- 5/- 1/- /- 5/6 3/- 4/- 3/- 4/- Zásobník G H Zásobník G H G H G H 5/6 1/- /- 1/- /- 5/6 3/- 4/7 8/- 3/- 4/7 Zásobník G Zásobník G F G H G H F 4
25 Průchod grafem do hloubky 5/6 1/- /- 1/- /- 5/6 8/9 3/- 4/7 8/9 3/10 4/7 Zásobník G Zásobník G H F G H F 11/- 11/- 1/- 1/- /- 5/6 1/- /- 5/6 8/9 3/10 4/7 8/9 3/10 4/7 Zásobník Zásobník G H F G H F 5
26 Průchod grafem do hloubky 1/13 11/- 1/- /- 5/6 8/9 3/10 4/7 8/9 3/10 4/7 Zásobník Zásobník G H F G H F 1/13 11/14 1/- 5/6 /- 1/13 11/14 1/- 5/6 /15 8/9 3/10 4/7 1/13 11/14 1/16 5/6 /15 8/9 3/10 4/7 Zásobník Zásobník G H F G H F 6
27 Průchod grafem do hloubky Životní cyklus uzlu při prohledávání grafu Fresh - open - closed ( čerstvý - otevřený - uzavřený ) Fresh Open losed Čerstvé uzly jsou všechny dosud ani jednou nenavštívené uzly. Před začátkem prohledávání jsou všechny uzly čerstvé. Při první návštěvě uzlu se uzel stává otevřeným. Množina čerstvých uzlů se během prohledávání nikdy nezvětšuje vzhledem k inkluzi. Otevřené uzly jsou alespoň jednou navštívené uzly, které dosud nebyly uzavřeny. Množina otevřených uzlů se může během prohledávání zvětšovat i zmenšovat. Uzavřené uzly jsou uzly, které už během prohledávání nebudou navštíveny. Pokud jsou všechny sousedy aktuálního uzlu otevřené nebo uzavřené, aktuální uzel se stává uzavřeným. Množina uzavřených uzlů se během prohledávání nikdy nezmenšuje vzhledem k inkluzi. Na konci prohledávání jsou všechny uzly uzavřené. 7
28 Průchod grafem do hloubky Implementační poznámka Fresh: Čerstvý uzel nemá přiřazen otevírací (ani zavírací) čas. Open: Otevřený uzel nemá přiřazen zavírací čas. losed: Uzavřený uzel má přiřazen zavírací čas. Otevírací a zavírací časy uzlů v některých případech prohledávání není nutno udržovat. Při iterativním prohledávání s vlastním zásobníkem je ale nutno průběžně udržovat informaci u každého uzlu, zda je čerstvý, otevřený nebo zavřený. V rekurzivním zpracování není nutno dělat explicitně ani to. Každé volání rekurzivní funkce odpovídá zpracování jednoho uzlu a všem jeho návštěvám. Při zavolání funkce se otevírá uzel, který je aktuálním parametrem volání, a na konci volání se tento uzel uzavírá. V těle funkce probíráme postupně sousedy aktuálního uzlu a voláme rekurzivně prohledávání pouze na ty z nich, které jsou ještě čerstvé (fresh). Stačí pak v každém uzlu udržovat jen informaci jednobitovou -- fresh nebo not fresh. 8
29 Průchod grafem do hloubky Postupný obsah zásobníku G G H G H G H G G F G -- Výpis (zpracování) uzlu při otevírání uzlu vede na posloupnost G H F Výpis (zpracování) uzlu při zavírání uzlu vede na posloupnost H F G Zpracování uzlu při jeho závírání se uplatní např. při hledání mostů nebo artikulací v neorientovaném grafu a při detekci silně souvislých komponent v orientovaném grafu. 9
30 Průchod grafem do hloubky Strom průchodu do hloubky s otevíracími a zavíracími časy jednotlivých uzlů 1/13 11/14 1/16 5/6 /15 3/10 G /15 1/16 11/14 8/9 3/10 4/7 4/7 H 8/9 F 1/13 5/6 Všimněme si, že v podstromu s kořenem X pro každý uzel Y různý od X platí Open_time(X) Open_time(Y) lose_time(y) lose_time(x). Naopak, pokud Y neleží v podstromu s kořenem X, pak platí lose_time(x) Open_time(Y) nebo lose_time(y) Open_time(X) Počet uzlů v podstromu s kořenem X je pak ( lose_time(y) + 1 Open_time(X) ) /. 30
31 Průchod grafem do hloubky void FS_rec_full( int start ) { vector<int> opent( N, 0 ); vector<int> closet( N, 0 ); vector<int> pred( N, -1 ); // -1 == no predecessor int time = 0; FS_rec_full( start, time, opent, closet, pred ); } for( int n = 0; n < N; n++ ) cout << "node " << n << " open/close " << opent[n] << "/"<< closet[n] << " pred " << pred[n] << endl; 31
32 Průchod grafem do hloubky rekurzivně void FS_rec_full( int currnode, int & time, vector<int> & opent, vector<int> & closet, vector<int> & pred ){ } int neigh; opent[currnode] = ++time; for( int j = 0; j < edge[currnode].size(); j++ ){ neigh = edge[currnode][j]; if( opent[neigh] == 0 ) { pred[neigh] = currnode; FS_rec_full( neigh, time, opent, closet, pred ); cout << currnode << " --> " << neigh << endl; } } closet[currnode] = ++time; 3
33 Průchod grafem do hloubky rekurzivně, základní varianta void FS_rec_plain( int currnode, vector<bool> & fresh ){ int neigh; fresh[currnode] = false; for( int j = 0; j < edge[currnode].size(); j++ ){ neigh = edge[currnode][j]; if( fresh[neigh] ) { FS_rec_plain( neigh, fresh ); cout << currnode << " --> " << neigh << endl; } } } void FS_rec_plain( int start) { vector<bool> fresh( N, true ); FS_rec_plain(start, fresh); } 33
34 Průchod grafem do šířky Životní cyklus uzlu při prohledávání grafu je koncepčně identický jako při prohledávání do hloubky Fresh Open losed Čerstvé uzly jsou všechny dosud ani jednou nenavštívené uzly. Před začátkem prohledávání jsou všechny uzly čerstvé. Při první návštěvě uzlu se uzel stává otevřeným. Množina čerstvých uzlů se během prohledávání nikdy nezvětšuje vzhledem k inkluzi. Otevřené uzly jsou alespoň jednou navštívené uzly, které dosud nebyly uzavřeny. Množina otevřených uzlů se může během prohledávání zvětšovat i zmenšovat. Uzavřené uzly jsou uzly, které už během prohledávání nebudou navštíveny. Pokud jsou všechny sousedy aktuálního uzlu otevřené nebo uzavřené, aktuální uzel se stává uzavřeným. Množina uzavřených uzlů se během prohledávání nikdy nezmenšuje vzhledem k inkluzi. Na konci prohledávání jsou všechny uzly uzavřené. 34
35 Průchod grafem do šířky Fronta Fronta Fronta F Fronta F G 35
36 Průchod grafem do šířky Fronta F G Fronta F G Fronta F G Fronta F G 36
37 Průchod grafem do šířky Fronta F G Fronta G F F G Fronta H Fronta H F G F G 37
38 Průchod grafem do šířky Fronta H Fronta H F G F G Fronta H Fronta F G H F G H 38
39 Průchod grafem do šířky Strom průchodu do šířky s vzdálenostmi od kořene jednotlivých uzlů F G 1 1 H Hloubka uzlu ve stromu průchodu do šířky je rovna jeho vzdálenosti od startovního uzlu. Na rozdíl od průchodu do hloubky nejsou otevírací a zavírací časy důležité. Průchod do šířky se uplatní např. při testování souvislosti grafu, testování existence cyklů ve grafu, testování bipartitnosti a zejména při výpočtu vzdálenosti mezi startovním a cílovým uzlem. 39
40 Průchod grafem do šířky Implementační poznámka Fresh: Čerstvý uzel nemá přiřazenu vzdálenost od startovního uzlu. Open: Otevřený uzel má přiřazen zavírací čas a je ve frontě. losed: Uzavřený uzel má přiřazen zavírací čas a není ve frontě. Stavy fresh/open/closed není nutno explicitně udržovat, obsah fronty společně s vzdáleností jednoznačně tyto stavy určují každému uzlu. Průchod do šířky je iterativní postup, rekurzivní varianta se nepoužívá (byla pouze nepřehlednější ). 40
41 Průchod grafem do šířky Pseudokód void graphreadthfirstsearch( Node startnode ) { Set visited = new Set(); // visited == not fresh Queue q = new Queue(); q.nqueue( startnode ); visited.add( startnode ); while(!q.mpty() ) { node = q.equeue(); print( node.key ); // process node forall x in node.neighbors() if( x not in visited ){ visited.add( x ); q.nqueue( x ); } } } 41
42 Průchod grafem do šířky v ++ void FS( int start ){ queue<int> q; vector<int> dist( N, -1 ); // fresh node vector<int> pred( N, -1 ); // no predecessor (yet) q.push( start ); dist[start] = 0; int currn, neigh; while(!q.empty() ){ currn = q.front(); q.pop(); cout << "node " << currn << endl; // process the node for( int j = 0; j < edge[currn].size(); j++ ){ neigh = edge[currn][j]; if( dist[neigh] == -1 ){ // neigh is fresh q.push( neigh ); dist[neigh] = dist[currn] + 1; pred[neigh] = currn; cout << "FS edge: " << currn << "->" << neigh << endl; } } } } 4
43 Průchod grafem do hloubky i do šířky symptotická složitost Každá jednotlivá operace se zásobníkem/frontou a s použitými datovými strukturami má konstantní složitost pro jeden uzel (včetně inicializace). Každý uzel jen jednou vstoupí do zásobníku/fronty a jednou z ní vystoupí. Stav uzlu (fresh/open/closed) se testuje tolikrát, kolik je stupeň tohoto uzlu. Součet stupnů všech uzlů je roven dvojnásobku počtu hran. elkem ( V + ). 43
44 Ořezávání Urychlení prohledávání Ořezávání neperspektivních větví Pokud jsme schopni na základě vyhodnocení momentálního stavu zjistit, že je to stav neperspektivní a že rozhodně nepovede k řešení úlohy odřízneme ze stromu celý podstrom momentálního stavu Strom prohledávání Momentální stav 44
45 Příklad ořezávání magický čtverec Magický čtverec řádu N o čtvercové schéma čísel velikost N x N o obsahuje právě jednou každé celé číslo od 1 do N o součet čísel ve všech řádcích a ve všech sloupcích stejný Příklad Triviální řešení: generování všech možných rozmístění čísel od 1 do N Ořezávání: kdykoliv je součet na řádku neperspektivní o součet všech čísel čtverce je ½ N (N +1) o součet čísel na řádku je ½ N (N +1) 45
46 Heuristiky Heuristika je návod, který nám říká, jaký postup řešení úlohy vede obvykle k rychlému dosažení výsledku. Nezaručuje vždy zrychlení výpočtu. Heuristika se používá pro stanovení pořadí, v jakém se zkoumají možné průchody stromem/grafem Příklad: úloha projít šachovým koněm celou šachovnici N x N účinná heuristika: nejprve se navštíví ta dosud nenavštívená pole, z nichž bude nejméně možností dalšího bezprostředního pokračování cesty koně. urychlení na šachovnici 8 x 8 až stotisíckrát. 46
ALGORITMIZACE 2010/03 STROMY, BINÁRNÍ STROMY VZTAH STROMŮ A REKURZE ZÁSOBNÍK IMPLEMENTUJE REKURZI PROHLEDÁVÁNÍ S NÁVRATEM (BACKTRACK)
ALGORITMIZACE 2010/03 STROMY, BINÁRNÍ STROMY VZTAH STROMŮ A REKURZE ZÁSOBNÍK IMPLEMENTUJE REKURZI PROHLEDÁVÁNÍ S NÁVRATEM (BACKTRACK) Strom / tree uzel, vrchol / node, vertex hrana / edge vnitřní uzel
Stromy. Karel Richta a kol. Katedra počítačů Fakulta elektrotechnická České vysoké učení technické v Praze Karel Richta a kol.
Stromy Karel Richta a kol. Katedra počítačů Fakulta elektrotechnická České vysoké učení technické v Praze Karel Richta a kol., 2018, B6B36DSA 01/2018, Lekce 9 https://cw.fel.cvut.cz/wiki/courses/b6b36dsa/start
ALGORITMIZACE 2010/03 STROMY, BINÁRNÍ STROMY VZTAH STROMŮ A REKURZE ZÁSOBNÍK IMPLEMENTUJE REKURZI PROHLEDÁVÁNÍ S NÁVRATEM (BACKTRACK)
ALGORITMIZACE 2010/03 STROMY, BINÁRNÍ STROMY VZTAH STROMŮ A REKURZE ZÁSOBNÍK IMPLEMENTUJE REKURZI PROHLEDÁVÁNÍ S NÁVRATEM (BACKTRACK) Strom / tree uzel, vrchol / node, vertex hrana / edge vnitřní uzel
Úvod do teorie grafů
Úvod do teorie grafů Neorientovaný graf G = (V,E,I) V množina uzlů (vrcholů) - vertices E množina hran - edges I incidence incidence je zobrazení, buď: funkce: I: E V x V relace: I E V V incidence přiřadí
Zdůvodněte, proč funkce n lg(n) roste alespoň stejně rychle nebo rychleji než než funkce lg(n!). Symbolem lg značíme logaritmus o základu 2.
1 3 4 5 6 7 8 9 10 11 1 13 14 15 16 17 18 19 0 1 3 4 5 6 7 8 9 30 31 3 Zdůvodněte, proč funkce f(n) = n log(n) 1 n 1/ roste rychleji než funkce g(n) = n. Zdůvodněte, proč funkce f(n) = n 3/ log(n) roste
ORIENTOVANÉ GRAFY, REPREZENTACE GRAFŮ
ORIENTOVANÉ GRAFY, REPREZENTACE GRAFŮ Doc. RNDr. Josef Kolář, CSc. Katedra teoretické informatiky, FIT České vysoké učení technické v Praze BI-GRA, LS 2/2, Lekce Evropský sociální fond Praha & EU: Investujeme
Vzdálenost uzlů v neorientovaném grafu
Vzdálenosti a grafy Vzdálenost uzlů v neorientovaném grafu Je dán neorientovaný neohodnocený graf G = (V,E,I) vzdálenost uzlů u a v v neorientovaném souvislém grafu G je délka nejkratší cesty spojující
Řešení: PŘENESVĚŽ (N, A, B, C) = přenes N disků z A na B pomocí C
Hanojské věže - 3 kolíky A, B, C - na A je N disků různé velikosti, seřazené od největšího (dole) k nejmenšímu (nahoře) - kolíky B a C jsou prázdné - úkol: přenést všechny disky z A na B, mohou se odkládat
Jan Březina. 7. března 2017
TGH03 - stromy, ukládání grafů Jan Březina Technical University of Liberec 7. března 2017 Kružnice - C n V = {1, 2,..., n} E = {{1, 2}, {2, 3},..., {i, i + 1},..., {n 1, n}, {n, 1}} Cesta - P n V = {1,
STROMOVE ALGORITMY Prohledavani do sirky (level-order) Po vodorovnejch carach fronta
STROMOVE ALGORITMY Prohledavani do sirky (level-order) Po vodorovnejch carach vlož do fronty kořen opakuj, dokud není fronta prázdná 1. vyber uzel z fronty a zpracuj jej 2. vlož do fronty levého následníka
Konstruktory a destruktory
Konstruktory a destruktory Nedostatek atributy po vytvoření objektu nejsou automaticky inicializovány hodnota atributů je náhodná vytvoření metody pro inicializaci, kterou musí programátor explicitně zavolat,
TGH05 - aplikace DFS, průchod do šířky
TGH05 - aplikace DFS, průchod do šířky Jan Březina Technical University of Liberec 31. března 2015 Grafová formulace CPM (critical path method) Orientovaný acyklický graf (DAG) je orientovaný graf neobsahující
Stromy. Strom: souvislý graf bez kružnic využití: počítačová grafika seznam objektů efektivní vyhledávání výpočetní stromy rozhodovací stromy
Stromy úvod Stromy Strom: souvislý graf bez kružnic využití: počítačová grafika seznam objektů efektivní vyhledávání výpočetní stromy rozhodovací stromy Neorientovaný strom Orientovaný strom Kořenový orientovaný
PROHLEDÁVÁNÍ GRAFŮ. Doc. RNDr. Josef Kolář, CSc. Katedra teoretické informatiky, FIT České vysoké učení technické v Praze
PROHLEDÁVÁNÍ GRAFŮ Doc. RNDr. Josef Kolář, CSc. Katedra teoretické informatiky, FIT České vysoké učení technické v Praze BI-GRA, LS 2010/2011, Lekce 4 Evropský sociální fond Praha & EU: Investujeme do
prohled av an ı graf u Karel Hor ak, Petr Ryˇsav y 16. bˇrezna 2016 Katedra poˇ c ıtaˇ c u, FEL, ˇ CVUT
prohledávání grafů Karel Horák, Petr Ryšavý 16. března 2016 Katedra počítačů, FEL, ČVUT Příklad 1 Nad frontou (queue) byly provedeny následující operace: push(1) push(2) print(poll()) print(peek()) print(peek())
Grafové algoritmy. Programovací techniky
Grafové algoritmy Programovací techniky Grafy Úvod - Terminologie Graf je datová struktura, skládá se z množiny vrcholů V a množiny hran mezi vrcholy E Počet vrcholů a hran musí být konečný a nesmí být
Grafové algoritmy. Programovací techniky
Grafové algoritmy Programovací techniky Grafy Úvod - Terminologie Graf je datová struktura, skládá se z množiny vrcholů V a množiny hran mezi vrcholy E Počet vrcholů a hran musí být konečný a nesmí být
Prohledávání do šířky = algoritmus vlny
Prohledávání do šířky = algoritmus vlny - souběžně zkoušet všechny možné varianty pokračování výpočtu, dokud nenajdeme řešení úlohy průchod stromem všech možných cest výpočtu do šířky, po vrstvách (v každé
Dynamické programování
ALG 0 Dynamické programování zkratka: DP Zdroje, přehledy, ukázky viz https://cw.fel.cvut.cz/wiki/courses/a4balg/literatura_odkazy 0 Dynamické programování Charakteristika Neřeší jeden konkrétní typ úlohy,
NEJKRATŠÍ CESTY I. Doc. RNDr. Josef Kolář, CSc. Katedra teoretické informatiky, FIT České vysoké učení technické v Praze
NEJKRATŠÍ CESTY I Doc. RNDr. Josef Kolář, CSc. Katedra teoretické informatiky, FIT České vysoké učení technické v Praze BI-GRA, LS 2010/2011, Lekce 7 Evropský sociální fond Praha & EU: Investujeme do vaší
Dynamické datové struktury I.
Dynamické datové struktury I. Seznam. Fronta. Zásobník. Tomáš Bayer bayertom@natur.cuni.cz Katedra aplikované geoinformatiky a kartografie, Přírodovědecká fakulta UK. Tomáš Bayer bayertom@natur.cuni.cz
5 Rekurze a zásobník. Rekurzivní volání metody
5 Rekurze a zásobník Při volání metody z metody main() se do zásobníku uloží aktivační záznam obsahující - parametry - návratovou adresu, tedy adresu, kde bude program pokračovat v metodě main () po skončení
Hledáme efektivní řešení úloh na grafu
Hledáme efektivní řešení úloh na grafu Mějme dán graf následující úlohy: G = ( V, E), chceme algoritmicky vyřešit Je daný vrchol t dosažitelný z vrcholu s? Pokud ano, jaká nejkratší cesta tyto vrcholy
Stromy. Příklady. Rekurzivní datové struktury. Základní pojmy
Základní pojmy Stromy doc. Ing. Miroslav Beneš, Ph.D. katedra informatiky FEI VŠB-TUO A-1007 / 597 324 213 http://www.cs.vsb.cz/benes Miroslav.Benes@vsb.cz Graf uzly hrany orientované / neorientované Souvislý
TGH05 - aplikace DFS, průchod do šířky
TGH05 - aplikace DFS, průchod do šířky Jan Březina Technical University of Liberec 28. března 2017 Grafová formulace CPM (critical path method) Orientovaný acyklický graf (DAG) je orientovaný graf neobsahující
Datové struktury. alg12 1
Datové struktury Jedna z klasických knih o programování (autor prof. Wirth) má název Algorithms + Data structures = Programs Datová struktura je množina dat (prvků, složek, datových objektů), pro kterou
Algoritmy na ohodnoceném grafu
Algoritmy na ohodnoceném grafu Dvě základní optimalizační úlohy: Jak najít nejkratší cestu mezi dvěma vrcholy? Dijkstrův algoritmus s t Jak najít minimální kostru grafu? Jarníkův a Kruskalův algoritmus
07 Základní pojmy teorie grafů
07 Základní pojmy teorie grafů (definice grafu, vlastnosti grafu, charakteristiky uzlů, ohodnocené grafy) Definice grafu množina objektů, mezi kterými existují určité vazby spojující tyto objekty. Uspořádaná
Matice sousednosti NG
Matice sousednosti NG V = [ v ij ] celočíselná čtvercová matice řádu U v ij = ρ -1 ( [u i, u j ] )... tedy počet hran mezi u i a u j?jaké vlastnosti má matice sousednosti?? Smyčky, rovnoběžné hrany? V
Algoritmy a datové struktury
Algoritmy a datové struktury Stromy 1 / 32 Obsah přednášky Pole a seznamy Stromy Procházení stromů Binární stromy Procházení BS Binární vyhledávací stromy 2 / 32 Pole Hledání v poli metodou půlení intervalu
Stromy, haldy, prioritní fronty
Stromy, haldy, prioritní fronty prof. Ing. Pavel Tvrdík CSc. Katedra počítačů FEL České vysoké učení technické DSA, ZS 2008/9, Přednáška 6 http://service.felk.cvut.cz/courses/x36dsa/ prof. Pavel Tvrdík
bfs, dfs, fronta, zásobník, prioritní fronta, halda
bfs, dfs, fronta, zásobník, prioritní fronta, halda Petr Ryšavý 20. září 2016 Katedra počítačů, FEL, ČVUT prohledávání grafů Proč prohledávání grafů Zkontrolovat, zda je sít spojitá. Hledání nejkratší
1 2 3 4 5 6 součet cvičení celkem. známka. Úloha č.: max. bodů: skut. bodů:
Úloha č.: max. bodů: skut. bodů: 1 2 3 4 5 6 součet cvičení celkem 20 12 20 20 14 14 100 známka UPOZORNĚNÍ : a) Písemná zkouška obsahuje 6 úloh, jejichž řešení musí být vepsáno do připraveného formuláře.
bfs, dfs, fronta, zásobník, prioritní fronta, halda
bfs, dfs, fronta, zásobník, prioritní fronta, halda Petr Ryšavý 19. září 2017 Katedra počítačů, FEL, ČVUT prohledávání grafů Proč prohledávání grafů Zkontrolovat, zda je sít spojitá. Hledání nejkratší
Šablony, kontejnery a iterátory
7. října 2010, Brno Připravil: David Procházka Šablony, kontejnery a iterátory Programovací jazyk C++ Šablony Strana 2 / 21 Šablona funkce/metody Šablona je obecný popis (třídy, funkce) bez toho, že by
Základní datové struktury III: Stromy, haldy
Základní datové struktury III: Stromy, haldy prof. Ing. Pavel Tvrdík CSc. Katedra počítačových systémů Fakulta informačních technologií České vysoké učení technické v Praze c Pavel Tvrdík, 2010 Efektivní
Dynamické datové struktury IV.
Dynamické datové struktury IV. Prioritní fronta. Tomáš Bayer bayertom@natur.cuni.cz Katedra aplikované geoinformatiky a kartografie, Přírodovědecká fakulta UK. Tomáš Bayer bayertom@natur.cuni.cz (Katedra
Abstraktní datové typy
Karel Müller, Josef Vogel (ČVUT FIT) Abstraktní datové typy BI-PA2, 2011, Přednáška 10 1/27 Abstraktní datové typy Ing. Josef Vogel, CSc Katedra softwarového inženýrství Katedra teoretické informatiky,
Algoritmizace prostorových úloh
INOVACE BAKALÁŘSKÝCH A MAGISTERSKÝCH STUDIJNÍCH OBORŮ NA HORNICKO-GEOLOGICKÉ FAKULTĚ VYSOKÉ ŠKOLY BÁŇSKÉ - TECHNICKÉ UNIVERZITY OSTRAVA Algoritmizace prostorových úloh Grafové úlohy Daniela Szturcová Tento
Datové struktury. Obsah přednášky: Definice pojmů. Abstraktní datové typy a jejich implementace. Algoritmizace (Y36ALG), Šumperk - 12.
Obsah přednášky: Definice pojmů o datový typ, o abstraktní datový typ Datové struktury Abstraktní datové typy a jejich implementace o Fronta (Queue) o Zásobník (Stack) o Množina (Set) Algoritmizace (Y36ALG),
1. Převeďte dané číslo do dvojkové, osmičkové a šestnáctkové soustavy: a) 759 10 b) 2578 10
Úlohy- 2.cvičení 1. Převeďte dané číslo do dvojkové, osmičkové a šestnáctkové soustavy: a) 759 10 b) 2578 10 2. Převeďte dané desetinné číslo do dvojkové soustavy (DEC -> BIN): a) 0,8125 10 b) 0,35 10
Obsah prezentace. Základní pojmy v teorii o grafech Úlohy a prohledávání grafů Hledání nejkratších cest
Obsah prezentace Základní pojmy v teorii o grafech Úlohy a prohledávání grafů Hledání nejkratších cest 1 Základní pojmy Vrchol grafu: {množina V} Je to styčná vazba v grafu, nazývá se též uzlem, prvkem
Úloha ve stavovém prostoru SP je <s 0, C>, kde s 0 je počáteční stav C je množina požadovaných cílových stavů
Stavový prostor a jeho prohledávání SP = formalismus k obecnějšímu uchopení a vymezení problému, který spočívá v nalezení posloupnosti akcí vedoucích od počátečního stavu úlohy (zadání) k požadovanému
Programování v C++ 2, 4. cvičení
Programování v C++ 2, 4. cvičení statické atributy a metody, konstruktory 1 1 Fakulta jaderná a fyzikálně inženýrská České vysoké učení technické v Praze Zimní semestr 2018/2019 Přehled Přístupová práva
Použití dalších heuristik
Použití dalších heuristik zkracování cesty při FIND-SET UNION podle hodností Datové struktury... p[x] - předchůdce uzlu x MAKE-SET(x) p[x] := x hod[x] := 0 hod[x] - hodnost (aprox. výšky) UNION(x,y) LINK(FIND-SET(x),
Prioritní fronta, halda
Prioritní fronta, halda Priority queue, heap Jan Kybic http://cmp.felk.cvut.cz/~kybic kybic@fel.cvut.cz 2016 2018 1 / 26 Prioritní fronta Halda Heap sort 2 / 26 Prioritní fronta (priority queue) Podporuje
Šablony, kontejnery a iterátory
11. března 2015, Brno Připravil: David Procházka Šablony, kontejnery a iterátory Programovací jazyk C++ Šablony Strana 2 / 31 Obsah přednášky 1 Šablony 2 Abstraktní datové struktury 3 Iterátory 4 Array
Základní datové struktury
Základní datové struktury Martin Trnečka Katedra informatiky, Přírodovědecká fakulta Univerzita Palackého v Olomouci 4. listopadu 2013 Martin Trnečka (UPOL) Algoritmická matematika 1 4. listopadu 2013
6. Tahy / Kostry / Nejkratší cesty
6. Tahy / Kostry / Nejkratší cesty BI-EP2 Efektivní programování 2 LS 2017/2018 Ing. Martin Kačer, Ph.D. 2011-18 Martin Kačer Katedra teoretické informatiky Fakulta informačních technologií České vysoké
bfs, dfs, fronta, zásobník
bfs, dfs, fronta, zásobník Petr Ryšavý 25. září 2018 Katedra počítačů, FEL, ČVUT prohledávání grafů Proč prohledávání grafů Zkontrolovat, zda je sít spojitá. Hledání nejkratší cesty, plánování cest. Prohledávání
ALGORITMY A DATOVÉ STRUKTURY
Název tématického celku: Cíl: ALGORITMY A DATOVÉ STRUKTURY Metodický list č. 1 Časová složitost algoritmů Základním cílem tohoto tematického celku je vysvětlení potřebných pojmů a definic nutných k popisu
IB108 Sada 1, Příklad 1 Vypracovali: Tomáš Krajča (255676), Martin Milata (256615)
IB108 Sada 1, Příklad 1 ( ) Složitost třídícího algoritmu 1/-Sort je v O n log O (n.71 ). Necht n = j i (velikost pole, které je vstupním parametrem funkce 1/-Sort). Lehce spočítáme, že velikost pole předávaná
Dynamické datové struktury III.
Dynamické datové struktury III. Halda. Tomáš Bayer bayertom@natur.cuni.cz Katedra aplikované geoinformatiky a kartografie, Přírodovědecká fakulta UK. Tomáš Bayer bayertom@natur.cuni.cz (Katedra aplikované
Algoritmizace prostorových úloh
INOVACE BAKALÁŘSKÝCH A MAGISTERSKÝCH STUDIJNÍCH OBORŮ NA HORNICKO-GEOLOGICKÉ FAKULTĚ VYSOKÉ ŠKOLY BÁŇSKÉ - TECHNICKÉ UNIVERZITY OSTRAVA Algoritmizace prostorových úloh Datové struktury Daniela Szturcová
2. Mřížky / Záplavové vyplňování
2. Mřížky / Záplavové vyplňování BI-EP2 Efektivní programování 2 LS 2017/2018 Ing. Martin Kačer, Ph.D. 2011-18 Martin Kačer Katedra teoretické informatiky Fakulta informačních technologií České vysoké
Základy informatiky. Teorie grafů. Zpracoval: Pavel Děrgel Úprava: Daniela Szturcová
Základy informatiky Teorie grafů Zpracoval: Pavel Děrgel Úprava: Daniela Szturcová Obsah přednášky Barvení mapy Teorie grafů Definice Uzly a hrany Typy grafů Cesty, cykly, souvislost grafů Barvení mapy
Datové typy a struktury
atové typy a struktury Jednoduché datové typy oolean = logická hodnota (true / false) K uložení stačí 1 bit často celé slovo (1 byte) haracter = znak Pro 8-bitový SII kód stačí 1 byte (256 možností) Pro
2) Napište algoritmus pro vložení položky na konec dvousměrného seznamu. 3) Napište algoritmus pro vyhledání položky v binárním stromu.
Informatika 10. 9. 2013 Jméno a příjmení Rodné číslo 1) Napište algoritmus pro rychlé třídění (quicksort). 2) Napište algoritmus pro vložení položky na konec dvousměrného seznamu. 3) Napište algoritmus
Algoritmizace prostorových úloh
INOVACE BAKALÁŘSKÝCH A MAGISTERSKÝCH STUDIJNÍCH OBORŮ NA HORNICKO-GEOLOGICKÉ FAKULTĚ VYSOKÉ ŠKOLY BÁŇSKÉ - TECHNICKÉ UNIVERZITY OSTRAVA Algoritmizace prostorových úloh Datové struktury Daniela Szturcová
Programování v C++ 1, 16. cvičení
Programování v C++ 1, 16. cvičení binární vyhledávací strom 1 1 Fakulta jaderná a fyzikálně inženýrská České vysoké učení technické v Praze Zimní semestr 2018/2019 Přehled 1 2 Shrnutí minule procvičené
Rekurzivní algoritmy
Rekurzivní algoritmy prof. Ing. Pavel Tvrdík CSc. Katedra počítačových systémů Fakulta informačních technologií České vysoké učení technické v Praze c Pavel Tvrdík, 2010 Efektivní algoritmy (BI-EFA) ZS
Programování 3. hodina. RNDr. Jan Lánský, Ph.D. Katedra informatiky a matematiky Fakulta ekonomických studií Vysoká škola finanční a správní 2015
Programování 3. hodina RNDr. Jan Lánský, Ph.D. Katedra informatiky a matematiky Fakulta ekonomických studií Vysoká škola finanční a správní 2015 Umíme z minulé hodiny Implementace zásobníku a fronty pomocí
TGH07 - Chytré stromové datové struktury
TGH07 - Chytré stromové datové struktury Jan Březina Technical University of Liberec 1. dubna 2014 Prioritní fronta Datová struktura s operacemi: Odeber Minum (AccessMin, DeleteMin) - vrat prvek s minimálním
Grafy. RNDr. Petra Surynková, Ph.D. Univerzita Karlova v Praze Matematicko-fyzikální fakulta.
6 RNDr., Ph.D. Katedra didaktiky matematiky Univerzita Karlova v Praze Matematicko-fyzikální fakulta petra.surynkova@mff.cuni.cz http://surynkova.info množina vrcholů a množina hran hrana vždy spojuje
Dynamicky vázané metody. Pozdní vazba, virtuální metody
Dynamicky vázané metody Pozdní vazba, virtuální metody Motivace... class TBod protected: float x,y; public: int vrat_pocet_bodu() return 1; ; od třídy TBod odvodíme: class TUsecka: public TBod protected:
Abstraktní datové typy: zásobník
Abstraktní datové typy: zásobník doc. Ing. Miroslav Beneš, Ph.D. katedra informatiky FEI VŠB-TUO A-1007 / 597 324 213 http://www.cs.vsb.cz/benes Miroslav.Benes@vsb.cz Abstraktní datové typy omezené rozhraní
Základní pojmy. Úvod do programování. Základní pojmy. Zápis algoritmu. Výraz. Základní pojmy
Úvod do programování Michal Krátký 1,Jiří Dvorský 1 1 Katedra informatiky VŠB Technická univerzita Ostrava Úvod do programování, 2004/2005 Procesor Procesorem je objekt, který vykonává algoritmem popisovanou
Michal Krátký. Úvod do programovacích jazyků (Java), 2006/2007
Úvod do programovacích jazyků (Java) Michal Krátký Katedra informatiky VŠB Technická univerzita Ostrava Úvod do programovacích jazyků (Java), 2006/2007 c 2006 Michal Krátký Úvod do programovacích jazyků
Základy informatiky. 07 Teorie grafů. Kačmařík/Szturcová/Děrgel/Rapant
Základy informatiky 07 Teorie grafů Kačmařík/Szturcová/Děrgel/Rapant Obsah přednášky barvení mapy teorie grafů definice uzly a hrany typy grafů cesty, cykly, souvislost grafů Barvení mapy Kolik barev je
ADT prioritní fronta. Haldy. Další operace nad haldou. Binární halda. Binomické stromy. Časová složitost jednotlivých operací.
ADT prioritní fronta Haldy množina M operace Přidej(M,x) přidá prvek x do množiny M Odeber(M) odeber z množiny M prvek, který je na řadě Zásobník (LIFO), Fronta (FIFO) Prioritní fronta: Přidej(M,x) přidá
V případě jazyka Java bychom abstraktní datový typ Time reprezentující čas mohli definovat pomocí třídy takto:
20. Programovací techniky: Abstraktní datový typ, jeho specifikace a implementace. Datový typ zásobník, fronta, tabulka, strom, seznam. Základní algoritmy řazení a vyhledávání. Složitost algoritmů. Abstraktní
Grafy. doc. Mgr. Jiří Dvorský, Ph.D. Katedra informatiky Fakulta elektrotechniky a informatiky VŠB TU Ostrava. Prezentace ke dni 13.
Grafy doc. Mgr. Jiří Dvorský, Ph.D. Katedra informatiky Fakulta elektrotechniky a informatiky VŠB TU Ostrava Prezentace ke dni 13. března 2017 Jiří Dvorský (VŠB TUO) Grafy 104 / 309 Osnova přednášky Grafy
Prohledávání do šířky a do hloubky. Jan Hnilica Počítačové modelování 15
Prohledávání do šířky a do hloubky Jan Hnilica Počítačové modelování 15 1 Prohledávací algoritmy Úkol postupně systematicky prohledat vymezený stavový prostor Stavový prostor (SP) možné stavy a varianty
Dijkstrův algoritmus
Dijkstrův algoritmus Hledání nejkratší cesty v nezáporně hranově ohodnoceném grafu Necht je dán orientovaný graf G = (V, H) a funkce, která každé hraně h = (u, v) H přiřadí nezáporné reálné číslo označované
Programování v C++ 1, 5. cvičení
Programování v C++ 1, 5. cvičení konstruktory, nevirtuální dědění 1 1 Fakulta jaderná a fyzikálně inženýrská České vysoké učení technické v Praze Zimní semestr 2018/2019 Přehled 1 2 3 Shrnutí minule procvičené
Lineární datové struktury
Lineární datové struktury doc. Mgr. Jiří Dvorský, Ph.D. Katedra informatiky Fakulta elektrotechniky a informatiky VŠB TU Ostrava Prezentace ke dni 13. března 2017 Jiří Dvorský (VŠB TUO) Lineární datové
Rekurze a zásobník. Jak se vypočítá rekurzivní program? volání metody. vyšší adresy. main(){... fa(); //push ret1... } ret1
Rekurze a zásobník Jak se vypočítá rekurzivní program? volání metody vyšší adresy ret1 main(){... fa(); //push ret1... PC ret2 void fa(){... fb(); //push ret2... return //pop void fb(){... return //pop
DSA, První krok: máme dokázat, že pro left = right vrátí volání f(array, elem, left, right)
Indukcí dokažte následující výrok: pokud lef t a right jsou parametry funkce f a platí left right, pak volání f(array, left, right) vrátí minimální hodnotu z hodnot všech prvků v poli array na indexech
Kapitola 11. Vzdálenost v grafech. 11.1 Matice sousednosti a počty sledů
Kapitola 11 Vzdálenost v grafech V každém grafu lze přirozeným způsobem definovat vzdálenost libovolné dvojice vrcholů. Hlavním výsledkem této kapitoly je překvapivé tvrzení, podle kterého lze vzdálenosti
Výhody a nevýhody jednotlivých reprezentací jsou shrnuty na konci kapitoly.
Kapitola Reprezentace grafu V kapitole?? jsme se dozvěděli, co to jsou grafy a k čemu jsou dobré. rzo budeme chtít napsat nějaký program, který s grafy pracuje. le jak si takový graf uložit do počítače?
ABSTRAKTNÍ DATOVÉ TYPY (ADT)
ABSTRAKTNÍ DATOVÉ TYPY (ADT) hierarchie abstrakcí: nejvyšší úroveň ZOO DruhZvirat celá čísla, řetězce nejnižší úroveň bity Abstrahujeme od - reprezentace (implementace) dat - realizace (implementace) operací
Programování v C++, 2. cvičení
Programování v C++, 2. cvičení 1 1 Fakulta jaderná a fyzikálně inženýrská České vysoké učení technické v Praze Zimní semestr 2018/2019 Přehled 1 Operátory new a delete 2 3 Operátory new a delete minule
Základy algoritmizace c2005, 2007 Michal Krátký, Jiří Dvorský1/39
Základy algoritmizace Michal Krátký 1, Jiří Dvorský 1 1 Katedra informatiky VŠB Technická univerzita Ostrava Základy algoritmizace, 2006/2007 Základy algoritmizace c2005, 2007 Michal Krátký, Jiří Dvorský1/39
Časová a prostorová složitost algoritmů
.. Časová a prostorová složitost algoritmů Programovací techniky doc. Ing. Jiří Rybička, Dr. ústav informatiky PEF MENDELU v Brně rybicka@mendelu.cz Hodnocení algoritmů Programovací techniky Časová a prostorová
Volné stromy. Úvod do programování. Kořenové stromy a seřazené stromy. Volné stromy
Volné stromy Úvod do programování Souvislý, acyklický, neorientovaný graf nazýváme volným stromem (free tree). Často vynecháváme adjektivum volný, a říkáme jen, že daný graf je strom. Michal Krátký 1,Jiří
STACK
Níže uvedené úlohy představují přehled otázek, které se vyskytly v tomto nebo v minulých semestrech ve cvičení nebo v minulých semestrech u zkoušky. Mezi otázkami semestrovými a zkouškovými není žádný
TGH07 - Chytré stromové datové struktury
TGH07 - Chytré stromové datové struktury Jan Březina Technical University of Liberec 5. dubna 2017 Prioritní fronta Datová struktura s operacemi: Odeber Minum (AccessMin, DeleteMin) - vrat prvek s minimálním
4 Stromy a les. Definice a základní vlastnosti stromů. Kostry grafů a jejich počet.
4 Stromy a les Jedním ze základních, a patrně nejjednodušším, typem grafů jsou takzvané stromy. Jedná se o souvislé grafy bez kružnic. Přes svou (zdánlivou) jednoduchost mají stromy bohatou strukturu a
Kolekce, cyklus foreach
Kolekce, cyklus foreach Jen informativně Kolekce = seskupení prvků (objektů) Jednu již známe pole (Array) Kolekce v C# = třída, která implementuje IEnumerable (ICollection) Cyklus foreach ArrayList pro
Implementace LL(1) překladů
Překladače, přednáška č. 6 Ústav informatiky, FPF SU Opava sarka.vavreckova@fpf.slu.cz Poslední aktualizace: 30. října 2007 Postup Programujeme syntaktickou analýzu: 1 Navrhneme vhodnou LL(1) gramatiku
Datové struktury 1: Základní datové struktury
Datové struktury 1: Základní datové struktury prof. Ing. Pavel Tvrdík CSc. Katedra počítačových systémů Fakulta informačních technologií České vysoké učení technické v Praze c Pavel Tvrdík, 2010 Efektivní
Algoritmy výpočetní geometrie
Algoritmy výpočetní geometrie prof. Ing. Pavel Tvrdík CSc. Katedra počítačových systémů Fakulta informačních technologií České vysoké učení technické v Praze c Pavel Tvrdík, 2010 Efektivní algoritmy (BI-EFA)
Přijímací zkouška - matematika
Přijímací zkouška - matematika Jméno a příjmení pište do okénka Číslo přihlášky Číslo zadání 1 Grafy 1 Pro který z následujících problémů není znám žádný algoritmus s polynomiální časovou složitostí? Problém,
PQ-stromy a rozpoznávání intervalových grafů v lineárním čase
-stromy a rozpoznávání intervalových grafů v lineárním čase ermutace s předepsanými intervaly Označme [n] množinu {1, 2,..., n}. Mějme permutaci π = π 1, π 2,..., π n množiny [n]. Řekneme, že množina S
1 Nejkratší cesta grafem
Bakalářské zkoušky (příklady otázek) podzim 2014 1 Nejkratší cesta grafem 1. Uvažujte graf s kladným ohodnocením hran (délka). Definujte formálně problém hledání nejkratší cesty mezi dvěma uzly tohoto
Martin Flusser. December 15, 2016
ZPRO cvičení 9 Martin Flusser Faculty of Nuclear Sciences and Physical Engineering Czech Technical University in Prague December 15, 2016 Outline I 1 Outline 2 Struktura 3 Struktury cv 4 Lineární spojový
Spojový seznam. Jan Kybic.
Spojový seznam Jan Kybic http://cmp.felk.cvut.cz/~kybic kybic@fel.cvut.cz 2016 2017 1 / 25 Složitost operací u lineárních datových struktur v Pythonu operace zásob. fronta pole pole řetězce přidej na začátek
DobSort. Úvod do programování. DobSort Implementace 1/3. DobSort Implementace 2/3. DobSort - Příklad. DobSort Implementace 3/3
DobSort Úvod do programování Michal Krátký 1,Jiří Dvorský 1 1 Katedra informatiky VŠB Technická univerzita Ostrava Úvod do programování, 2004/2005 V roce 1980 navrhl Dobosiewicz variantu (tzv. DobSort),
Hanojská věž. T2: prohledávání stavového prostoru. zadání [1 1 1] řešení [3 3 3] dva možné první tahy: [1 1 2] [1 1 3]
Hanojská věž zadání [1 1 1] řešení [3 3 3] dva možné první tahy: [1 1 2] [1 1 3] který tah je lepší? (co je lepší tah?) P. Berka, 2012 1/21 Stavový prostor 1. množina stavů S = {s} 2. množina přechodů
2 Datové struktury. Pole Seznam Zásobník Fronty FIFO Haldy a prioritní fronty Stromy Hash tabulky Slovníky
Pole Seznam Zásobník Fronty FIFO Haldy a prioritní fronty Stromy Hash tabulky Slovníky 25 Pole Datová struktura kolekce elementů (hodnot či proměnných), identifikovaných jedním nebo více indexy, ze kterých