Recent Changes - Search:

Oktatás

* Programozás 2
  + feladatsor
  + C feladatsor
  + Python feladatsor
  + GitHub oldal

* Szkriptnyelvek
  + feladatsor
  + quick link

* levelezősök
  + Adator. prog.
  + feladatsor
  + quick link

teaching assets


Félévek

* 2024/25/1
* archívum


Linkek

* kalendárium
   - munkaszüneti napok '20
* tételsorok
* jegyzetek
* szakdolgozat / PhD
* ösztöndíjak
* certificates
* C lang.
* C++
* C#
* Clojure
* D lang.
* Java
* Nim
* Scala


[ edit | logout ]
[ sandbox | passwd ]

Py /

20130528a

Gráfbejárások

A gráfokról itt olvashat többet: adatszerkezetek-11-20130430.pdf.

Tekintsük a következő gráfot:

Adjuk meg a gráf leírását egy fájlban JSON formátumban:

{
  "a": ["b", "f", "g"],
  "b": [],
  "c": ["a"],
  "d": ["f"],
  "e": ["d", "e"],
  "f": ["e"],
  "g": ["c", "e", "j"],
  "h": ["g", "i"],
  "i": ["h"],
  "j": ["k", "l", "m"],
  "k": [],
  "l": ["g", "m"],
  "m": ["l"]
}

A csúcsokat betűkkel címkézzük. A bejárás során 3 kategóriát különböztetünk meg ("fekete", "szürke", ill. "fehér" csúcsok). A fekete csúcsok lesznek a már bejárt csúcsok; a szürke csúcsok azok, melyeket már látunk a feketékből; a fehér csúcsok pedig még nem is látszanak. Amikor egyszerre több csúcsot is át kell tenni a 2. kategóriába (a "szürke" csúcsok közé), akkor a könnyebb ellenőrizhetőség kedvéért a csúcsokat ábécésorrendben tegyük be.

Szélességi bejárás

Járjuk be a gráfot az "a" csúcsból kiindulva szélességi bejárással, s írassuk ki a csúcsok bejárási sorrendjét. Ha a "szürke" csúcsok közé ábécésorrendben tettük be az elemeket, akkor a következő bejárási sorrendet kell kapnunk: a b f g e c j d k l m h i.

A szélességi bejárás esetén a "szürke" csúcsokat egy sor adatszerkezetben tároljuk. Ehhez felhasználhatjuk a köv. kódrészletet:

import Queue

q = Queue.Queue()

for i in range(5):
    q.put(i)

while not q.empty():
    print q.get()

A fenti kódrészlet kimenete:

$ python Queue_fifo.py

0
1
2
3
4

A Queue osztályról itt olvashat többet.

Mélységi bejárás

Járjuk be a gráfot az "a" csúcsból kiindulva mélységi bejárással, s írassuk ki a csúcsok bejárási sorrendjét. Ha a "szürke" csúcsok közé ábécésorrendben tettük be az elemeket, akkor a következő bejárási sorrendet kell kapnunk: a g j m l k e d c f b h i.

A mélységi bejárás esetén a "szürke" csúcsokat egy verem adatszerkezetben tároljuk. Ehhez felhasználhatjuk a köv. kódrészletet:

import Queue

q = Queue.LifoQueue()

for i in range(5):
    q.put(i)

while not q.empty():
    print q.get()

A fenti kódrészlet kimenete:

$ python Queue_lifo.py

4
3
2
1
0

A Queue osztályról itt olvashat többet.

Cloud City

  

Blogjaim, hobbi projektjeim

* The Ubuntu Incident
* Python Adventures
* @GitHub
* heroku
* extra
* haladó Python
* YouTube listák


Debrecen | la France


[ edit ]

Edit - History - Print *** Report - Recent Changes - Search
Page last modified on 2013 May 28, 21:21