Uzel (počítačová věda) - Node (computer science)
A uzel je základní jednotkou a datová struktura, jako je a spojový seznam nebo strom datová struktura. Uzly obsahují data a také může odkazovat na další uzly. Odkazy mezi uzly často implementuje ukazatele.
Uzly a stromy
Uzly jsou často uspořádány do stromových struktur. Uzel představuje informace obsažené v jedné datové struktuře. Tyto uzly mohou obsahovat hodnotu nebo podmínku nebo mohou sloužit jako další nezávislá datová struktura. Uzly jsou reprezentovány jedním nadřazeným uzlem. Nejvyšší bod ve stromové struktuře se nazývá kořenový uzel, který nemá nadřazený uzel, ale slouží jako rodič nebo „prarodič“ všech uzlů pod ním ve stromu. Výška uzlu je určena celkovým počtem okrajů na cestě z tohoto uzlu k nejvzdálenějšímu uzlu listu a výška stromu se rovná výšce kořenového uzlu.[1] Hloubka uzlu je určena vzdáleností mezi daným uzlem a kořenovým uzlem. Kořenový uzel má hloubku nula.[2] Data lze zjistit podél těchto síťových cest.[3]IP adresa používá tento druh systému uzlů k definování svého umístění v síti.
Definice
- Dítě: Podřízený uzel je uzel vyčnívající z jiného uzlu. Například počítač s přístupem na internet lze považovat za podřízený uzel uzlu představujícího internet. Inverzní vztah je vztah a nadřazený uzel. Pokud uzel C je dítětem uzlu A, pak A je nadřazený uzel C.
- Stupeň: stupeň uzlu je počet dětí uzlu.
- Hloubka: hloubka uzlu A je délka cesty od A do kořenového uzlu. Kořenový uzel má hloubku 0.
- Okraj: spojení mezi uzly.
- Les: sada stromů.
- Výška: výška uzlu A je délka nejdelší cesty skrz děti do listového uzlu.
- Interní uzel: uzel s alespoň jedním dítětem.
- Listový uzel: uzel bez dětí.
- Kořenový uzel: uzel odlišený od ostatních uzlů stromu. Obvykle je zobrazen jako nejvyšší uzel stromu.
- Sourozenecké uzly: jedná se o uzly připojené ke stejnému nadřazenému uzlu.
Značkovací jazyky
Další běžné použití uzlových stromů je v vývoj webových aplikací. V programování XML se používá ke komunikaci informací mezi počítačovými programátory a podobně. Z tohoto důvodu se XML používá k vytvoření společného komunikační protokoly použito v software pro kancelářskou produktivitu, a slouží jako základna pro vývoj moderního webu značkovací jazyky jako XHTML. Přestože programátor k tomu přistupuje podobně, HTML a CSS je obvykle jazyk používaný k vývoji textu a designu webových stránek. Zatímco XML, HTML a XHTML poskytují jazyk a výraz, DOM slouží jako překladatel.[4]
Typ uzlu
Různé typy uzlů ve stromu jsou reprezentovány konkrétními rozhraními. Jinými slovy, typ uzlu je definován tím, jak komunikuje s ostatními uzly. Každý uzel má vlastnost typu uzlu, která určuje typ uzlu, například sourozence nebo list. Například pokud je vlastnost typu uzlu konstantní vlastnosti uzlu, tato vlastnost určuje typ uzlu. Pokud je tedy vlastnost typu uzlu konstantní uzel ELEMENT_NODE, lze vědět, že tento objekt uzlu je objektovým prvkem. Tento objekt používá rozhraní Element k definování všech metod a vlastností daného konkrétního uzlu
Různé W3C World Wide Web Consortium typy a popisy uzlů:
- Dokument představuje celý dokument (kořenový uzel stromu DOM)
- DocumentFragment představuje "odlehčený" objekt dokumentu, který může obsahovat část dokumentu
- Typ dokumentu poskytuje rozhraní k entitám definovaným pro dokument
- Pokyny pro zpracování představuje instrukci zpracování
- EntityReference představuje odkaz na entitu
- Živel představuje prvek
- Attr představuje atribut
- Text představuje textový obsah v prvku nebo atributu
- CDATASection představuje sekci CDATA v dokumentu (text, který NENÍ analyzován analyzátorem)
- Komentář představuje komentář
- Subjekt představuje entitu
- Zápis představuje notaci deklarovanou v DTD
NodeType | Pojmenovaná konstanta |
---|---|
1 | ELEMENT_NODE |
2 | ATTRIBUTE_NODE |
3 | TEXT_NODE |
4 | CDATA_SECTION_NODE |
5 | ENTITY_REFERENCE_NODE |
6 | ENTITY_NODE |
7 | PROCESSING_INSTRUCTION_NODE |
8 | COMMENT_NODE |
9 | DOCUMENT_NODE |
10 | DOCUMENT_TYPE_NODE |
11 | DOCUMENT_FRAGMENT_NODE |
12 | NOTATION_NODE |
Uzel objekt
Objekt uzlu je reprezentován jedním uzlem ve stromu. Může to být uzel prvku, uzel atributu, textový uzel nebo jakýkoli typ popsaný v části „typ uzlu“. Všechny objekty mohou zdědit vlastnosti a metody pro práci s nadřazenými a podřízenými uzly, ale ne všechny objekty mají nadřazené nebo podřízené uzly. Například textové uzly, které nemohou mít podřízené uzly, podobné uzly pro přidání podřízených uzlů budou mít za následek DOM chyba.
Objekty ve stromu DOM mohou být adresovány a manipulovány pomocí metod na objektech. Veřejné rozhraní DOM je uvedeno v jeho aplikační programovací rozhraní (API). Historie modelu objektu dokumentu se prolíná s historií „války prohlížeče "z konce 90. let mezi Netscape Navigator a Microsoft Internet Explorer, stejně jako u JavaScript a JScript, první skriptovací jazyky které mají být široce implementovány v EU rozložení motory z internetové prohlížeče.
Viz také
Reference
- ^ "strom (datová struktura)". Národní institut pro standardy a technologie. Archivováno od originálu dne 2014-11-24.
- ^ Teukolsky, Roselyn (2013). Barronova AP Computer Science A. Barron. ISBN 978-1-4380-0152-4.
- ^ „Simply Scheme: Introducing Computer Science ch 18: Trees“. College of Engineering, University of California, Berkeley. Archivováno od originálu dne 2013-12-22.
- ^ "XML DOM Úvod". W3Schools. Archivovány od originál dne 06.06.2014. Citováno 2018-04-07.
externí odkazy
- Datové stromy jako prostředek prezentace komplexní analýzy dat autor: Sally Knipe
- Třída stromu C ++ podobná STL
- Popis stromových datových struktur z ideainfo.8m.com
- WormWeb.org: Interaktivní vizualizace C. elegans Buňkový strom - Vizualizujte celý strom buněčné linie hlístice C. elegans (javascript)