Skip to content

Latest commit

 

History

History
67 lines (45 loc) · 2.64 KB

README.md

File metadata and controls

67 lines (45 loc) · 2.64 KB

GAL2014

Repository for school project - implementation of Fleury's algorithm in C/C++

Eulerovsky graf - existuje v nem eulerovsky tah, tzn tah prochazejici vsemi hranami prave jenou Theorem: "Neorientovany graf G ma eulerovsky tah, prave kdyz je G souvisly a pocet vrcholu s lichym stupnem je 0 nebo 2" -je to proto ze bud je tah uzavreny (0 vrcholu s lichym stupnem) -nebo se v jednom zacne, v druhem skocni

Corollary: "Orientovany graf G ma eulerovsky tah, prave kdyz je G souvisly a pocet vrcholu s lichym stupnem je 0 nebo 2" -Orientovana kostra grafu G=(V,E) je orientovany strom T=(V,E') s korenem u z V, kde E' je podmnozinou E a d+(u)=0 a d+(v)=1 pro vsechna v z V-{u} -Vyvazeny graf G=(V,E) je orientovany graf s d+(u)=d-(u) pro vsechny u z V

Je-li G souvisly a vyvazeny orientovany graf s orientovanou kostrou T s korenem u, pak eulerovsky cyklus v reverznim       smeru lze zjistit nasledovne:
    a) Zacneme libovolnou hranou incidentni k u
    b) Dalsi hrany vybirame jako incidentni k aktualnimu uzlu takove, ze
        i) hrana jeste nebyla vybrana
        ii) zadna hrana z T se nevybere, dokud lze vybrat jinou
    c) Hledani konci, kdyz aktualni uzel nema incidentni zadne nepouzite hrany

Stupen - pocet incidentnich vrcholu - u neorientovaneho grafu - u orientovaneho se berou 2 stupne: -vystupni stupen a vstupni stupen

Postup pro GIT:

  1. Vzdy pred zacatkem prace dat git pull
  2. Po editaci nekterych souboru dat git commit -am "nejaka zprava o commitu"
  3. nakonec po 2. dat git push

Algoritmus!! hlavni myslenka: Don’t burn your bridges behind you. a.) 0 lichych uzlu - okruh b.) 2 liche uzly - cesta

Algoritmus: 1.) pokud plati podminka a.) vyber jako startovni uzel libovolny uzel pokud plati podminka b.) vyber jeden z lichych uzlu

2.) vyber takovou hranu, ktera neni BRIDGE, pokud nemas jinou moznost tak vyber prave ji

3.) Pokud nemas kam jit, konec. Konec je budto v pocatecnim bode (a) nebo v druhem lichem bode (b) Pokud mas kam jit, opakuj 2.)

-nejlepsi bude uchovavat 2 kopie grafu - jedna bude minulost (to co se uz proslo), druha bude budoucnost (to co jeste neni obarveny a musi se teprve projit)

Jak zjistit jestli je nejaka hrana bridge?? //nejdriv spocitam pocet dosazitelnych uzlu z uzlu u ve kterem jsem - pouziju uz seskrtany graf - visitedGraph count1 = DFS(visitedGraph, u)

//odstranim hranu (u,v) kterou zkoumam zda neni bridge remove(visitedGraph, (u,v))

//zjistim pocet dosazitelnych uzlu bez hrany (u,v) z uzlu u count2 = DFS(visitedGraph, u)

//nakonec: if(count1 < count2){ (u,v) je bridge a nemuzu se timto smerem vydat return true; }