Estruktura ng datos
Sa agham pangkompyuter, ang data structure (estruktura ng datos ay isang lohikal na pagsasaayos ng datos sa isang kompyuter upang magamit ito ng mas epektibo. Ito ay ang implementasyon ng abstract data type (tipo ng abstraktong datos) sa isang wikang pamprograma kung saan ang mga kaukulang operasyon ay maaaring gawin sa datos na nakapaloob dito. Ang iba't ibang klase ng estruktura ng datos ay may kanya-kanyang gamit. Sa katunayan, ang iba sa mga ito ay spesipiko lamang para sa isang gawain. Halimbawa, mas magandang gumamit ng mga punong binaryo kung madami ang datos na kailangan isaayos (katulad ng mga database) at ang array kung simpleng pagmamanipula lamang ng limitadong datos ang kailangan. Napaka-importante ng mga estruktura ng datos sa pag gawa ng mga sopwer sa kompyuter. Ang ilan sa mga epektibong algoritmo ay nangangailangan ng implementasyon ng mga estruktura ng datos upang tumakbo ng maayos. Kinakailangan din ito upang mapadali ang pag disenyo ng mga database kung saan importante ang pagkakasaayos ng datos.
Konsepto sa likod ng data structures
[baguhin | baguhin ang wikitext]Nakabase ang konsepto nito sa pagkuha ng datos ng kompyuter sa memorya nito. Kumbaga ang nangyayari sa data structure ay ang pagkukwenta ng mga address ng datos (katulad ng sa array) o di kaya ang pagtatago mismo ng address ng mga ito sa loob mismo ng data structure (linked list) upang makita ang mga elemento na kabilang sa estruktura na iyon.
Iba't ibang klase ng data structures
[baguhin | baguhin ang wikitext]Ang pinaka-laganap na data structure ay ang array. Halos lahat ng mga high-level programming language ay nag-iimplementa ng ganitong uri ng estruktura ng datos. Ang ilan pa sa mga karaniwang estruktura ng datos ang : stack, queue, pinagdugtong na listahan, punong binaryo.
Mga datatype (tipo ng datos)
[baguhin | baguhin ang wikitext]Tipong primitibo
[baguhin | baguhin ang wikitext]- Boolean (para sa mga halagang boolean na True/False)
- Char para sa mga halagang character
- Float para sa pag-iimbak(store) ng mga halagang real na bilang
- Double na mas malaking sukat ng tayp na float
- int para sa mga halagang integral(buo) o tiyak ang presisyon
- String para sa string o sunod sunod na character
- Enumerated type
Tipong kompuwesto
[baguhin | baguhin ang wikitext]- Array
- Record (na tinatawag ring tuple o struct)
- Union
- Tagged union (na tinatawag ring variant, variant record, discriminated union, o disjoint union)
- Plain old data structure
Tipong abstrakto
[baguhin | baguhin ang wikitext]Estruktura ng datos na lineal
[baguhin | baguhin ang wikitext]Arrays
[baguhin | baguhin ang wikitext]Listahan
[baguhin | baguhin ang wikitext]Trees (Puno)
[baguhin | baguhin ang wikitext]Binary trees (Punong binaryo)
[baguhin | baguhin ang wikitext]B-trees
[baguhin | baguhin ang wikitext]Heaps (bunton)
[baguhin | baguhin ang wikitext]Tries
[baguhin | baguhin ang wikitext]Multiway trees
[baguhin | baguhin ang wikitext]Space-partitioning trees
[baguhin | baguhin ang wikitext]- Segment tree
- Interval tree
- Range tree
- Bin
- Kd-tree
- Implicit kd-tree
- Min/max kd-tree
- Adaptive k-d tree
- Kdb tree
- Quadtree
- Octree
- Linear octree
- Z-order
- UB-tree
- R-tree
- R+ tree
- R* tree
- Hilbert R-tree
- X-tree
- Metric tree
- Cover tree
- M-tree
- VP-tree
- BK-tree
- Bounding interval hierarchy
- BSP tree
- Rapidly-exploring random tree