Struktur Data Tree
Tree Merupakan salah
satu bentuk struktur data tidak linear yang menggambarkan
hubungan yang bersifat hirarkis (hubungan one to many) antara elemen-elemen.
Tree bisa didefinisikan sebagai kumpulan simpul/node dengan satu elemen khusus
yang disebut Root dan node lainnya terbagi menjadi himpunan-himpunan yang
saling tak berhubungan satu sama lainnya (disebut subtree). Untuk jelasnya, di
bawah akan diuraikan istilah-istilah umum dalam tree :
- Prodecessor : node yang berada
diatas node tertentu.
- Successor : node yang berada di bawah node tertentu.
- Ancestor : seluruh node yang terletak sebelum node
tertentu dan terletak pada jalur yang sama.
- Descendant : seluruh node yang terletak sesudah node
tertentu dan terletak pada jalur yang sama.
- Parent : predecssor satu level di atas suatu node.
- Child : successor satu level di bawah suatu node.
- Sibling : node-node yang memiliki parent yang sama
dengan suatu node.
- Subtree : bagian dari tree yang berupa suatu node
beserta descendantnya dan memiliki semua karakteristik dari tree tersebut.
- Size : banyaknya node dalam suatu tree.
- Height : banyaknya tingkatan/level dalam suatu tree.
- Root : satu-satunya node khusus dalam tree yang tak
punya predecssor.
- Leaf : node-node dalam tree yang tak memiliki
seccessor.
- Degree : banyaknya child yang dimiliki suatu node.
Beberapa jenis Tree yang
memiliki sifat khusus :
1) Binary Tree
Binary Tree adalah tree dengan syarat
bahwa tiap node hanya boleh memiliki maksimal dua subtree dan kedua subtree
tersebut harus terpisah. Sesuai dengan definisi tersebut, maka tiap
node dalam binary tree hanya boleh memiliki paling banyak dua child.
![[40.JPG]](https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhJq2OEiMRCeg_DtikTJmzsPzZpjNfQ3Y4Qs4OaNZ0egk085UwjeX23QMCVfzphUXGahpQ8UnMq-ez8IpK9pNDjDrGdL7mB9XoWzckxO7CZxvoh9ACHeR2JI0UhJKEru-6yDMO7g4NtQXs/s1600/40.JPG)
Jenis-jenis Binary Tree
:
a) Full Binary Tree
![[41.JPG]](https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEioR4LV5T-jQ2pMmNox4xF2Mpim_Xs7xi8JPbcxDQ2F8AQRGCydeQ7_o7ulcdYvKgprt81ib6SDvJl0s9_RKHlxP_KxEgwM_YHsmfx4YGGygce6xZaACq7UA8yn9uypGd-UP5zoLSUFyYQ/s1600/41.JPG)
Binary Tree yang tiap
nodenya (kecuali leaf) memiliki dua child dan tiap subtree harus mempunyai
panjang path yang sama.
b) Complete Binary Tree
![[42.JPG]](https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEgZjMrpOGnn96hHMMrYKyfyCU3e5mjfw9LEBtCT2PV274ov99necPxzRj8ZRfEQM7p_Dti0-vHQ_Vz34SjyerEZ2DCXRg6wHo4CzVGVjdUkTLI2_HNOvoAiLza1aBQWXNAehYFiEl3VwxI/s1600/42.JPG)
Mirip dengan Full Binary
Tree, namun tiap subtree boleh memiliki panjang path yang berbeda. Node kecuali
leaf memiliki 0 atau 2 child.
c) Skewed Binary Tree
![[43.JPG]](https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEh9FeQgGot1RrqZmou2wfe_xlG7J8q_1OA3caDa9jOFmHYjgxLa9QCQYqguzl6fjyIHpPwBJQFrc4mOij8E5ZxQhkJSdfNdN2-MwI8Us8wYU-z6w4EMoBRmQxu1wPDbJIj3aRMqUeBnL2Y/s1600/43.JPG)
Binary Tree yang
semua nodenya (kecuali leaf) hanya memiliki satu child.
Implementasi
Binary TreeBinary Tree dapat
diimplemntasikan dalam Pascal dengan menggunakan double Linked List. Untuk
nodenya, bisa dideklarasikan sbb :Type Tree = ^node;Node = recordIsi : TipeData;Left,Right : Tree;end;
Contoh ilustrasi Tree
yang disusun dengan double linked list :
![[44.JPG]](https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEiNmssEeleUUNPR_P9wIebS3w4dD2-cFGEfqyiK0H1s5khyphenhyphenRXvQIEXlkoSdq8Fe430yqVoITHFws6_whXFyE5P-T4NCN0wjGbtijiKV2pRZNVGEisHBaCdKKFJhtOBUCLtf8V6lebVDtAk/s1600/44.JPG)
(Ket: LC=Left Child;
RC=Right Child)
Operasi-operasi pada Binary Tree :
v Create : Membentuk binary tree baru yang masih kosong.
v Clear : Mengosongkan binary tree yang sudah ada.
v Empty : Function untuk memeriksa apakah binary tree masih
kosong.
v Insert : Memasukkan sebuah node ke dalam
tree. Ada tiga pilihan insert: sebagai root, left child, atau right
child. Khusus insert sebagai root, tree harus dalam keadaan kosong.
v Find : Mencari root, parent, left child, atau right child
dari suatu node. (Tree tak boleh kosong)
v Update : Mengubah isi dari node yang ditunjuk oleh pointer
current. (Tree tidak boleh kosong)
v Retrieve : Mengetahui isi dari node yang ditunjuk pointer
current. (Tree tidak boleh kosong)
v DeleteSub : Menghapus sebuah subtree (node beserta seluruh
descendantnya) yang ditunjuk current. Tree tak boleh kosong. Setelah itu
pointer current akan berpindah ke parent dari node yang dihapus.
v Characteristic : Mengetahui karakteristik dari suatu tree, yakni :
size, height, serta average lengthnya. Tree tidak boleh kosong. (Average Length
= [jumlahNodeLvl1*1+jmlNodeLvl2*2+…+jmlNodeLvln*n]/Size)
v Traverse : Mengunjungi seluruh node-node pada tree,
masing-masing sekali. Hasilnya adalah urutan informasi secara linier yang
tersimpan dalam tree. Adatiga cara traverse : Pre Order, In Order, dan
Post Order.
Langkah-Langkahnya Traverse :Ø PreOrder : Cetak isi node yang dikunjungi, kunjungi Left
Child, kunjungi Right Child.
Ø InOrder : Kunjungi Left Child, Cetak isi node yang
dikunjungi, kunjungi Right Child.
Ø PostOrder : Kunjungi Left Child, Kunjungi Right Child, cetak
isi node yang dikunjungi.
Untuk
lebih jelasnya perhatikan contoh operasi-operasi pada Binary Tree berikut ini :
![[45.JPG]](https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhI16JXmRUazAhEFoArQJ3C6Zmz9h1Fi1vBPhbVJh65eZPiSYkgiG3_LTPtGN14-m0xauPBrfgG-6ZYR0OTDU-RLmB38Vl13zVrw9Nl2v3mW30SsQGFxrI7R7wws00IZm9nzB7stJ3-ZT4/s1600/45.JPG)
![[46.JPG]](https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEi_Li_6Sm3JU84hW_SjpHCpuLyr0Kn48I09wJkezIFOPwjDTFLwYe-2E8MIbhJkqlP6Ajq3CMg6J_b9Sn5wZVCEmJcWtXHfrId8i2YV4srx3XBKYxeQTTCS7R2FGo44zYjteXxaxlHRAT8/s1600/46.JPG)
![[47.JPG]](https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEiRICtoHH0O3rTGwJcRhfV77qOcA_xAP6y5uPD1y0RDReb-x89mBuoXVFlASCD6cQn2JHnlJNQsxTb99wDl66YPprxiqrEiarQ4qF12XfTtCjoM-JVbWI1HhaHUNk8aJS-7cMSsrwdr6wA/s1600/47.JPG)
2) Binary search
Tree adalah Binary Tree
dengan sifat bahwa semua left child harus lebih kecil daripada right child dan
parentnya. Juga semua right child harus lebih besar dari left child serta
parentnya. Binary seach tree dibuat untuk mengatasi kelemahan pada binary tree
biasa, yaitu kesulitan dalam searching / pencarian node tertentu dalam binary
tree.
Contoh binary search tree umum :
![[48.JPG]](https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEi4ieVMzZAOrSkWwB9-raC5Sw0ej68BMw8Pyy8dG0nA7kkJI4JB-a7ZLESMJnyecCp9eJS2Js6thKAbxn6ygsgQxHL8C5FTW52fxNpyqM1pcM76XdWn4Zlvq7-8qTiJD2AVhimIP8bD2Fo/s1600/48.JPG)
Pada dasarnya operasi dalam
binary search tree sama dengan Binary tree biasa, kecuali pada operasi insert,
update, dan delete.
1. Insert : Pada Binary Search Tree, insert dilakukan
setelah ditemukan lokasi yang tepat. (Lokasi tidak ditentukan oleh user
sendiri).
![[49.JPG]](https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjfqVpH74uQq0w_DDrW9m0pgPi4U29CpfXjHaoydjY35pKJwW7kDArlxtUI9yGyjlwxHScoezQ6sTUSYzCZDCMdYZ9hQA4qAuEQq3V4LJFbs8Zg9a9vIF9rSsqz-L6jcpmT3u8Z8hygqSE/s1600/49.JPG)
![[50.JPG]](https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEiDgj991En6iwKnPBRh1dlDFqy_uGzHODN21VxupP8qoG6BAdaA4qliivGuOZAKP8PC-BxlhacdEzRBAAsKDPVf4iRWAcvY2qsXZupzn0lRsptfWxq25YkmWJXYC0MSNmF_koprqQ04Mig/s1600/50.JPG)
2. Update : Seperti pada Binary
Tree biasa, namun disini uapte akan berpengaruh pada posisi node tersebut
selanjutnya. Bila setelah diupdate mengakibatkan tree tersebut bukan Binary
Search Tree lagi, maka harus dilakukan perubahan pada tree dengan melakukan
perubahan pada tree dengan melakukan rotasi supaya tetap menjadi Binary Search
Tree.
3. Delete : Seperti halnya update, delete
dalam Binary Search Tree juga turut mempengaruhi struktur dari tree
tersebut.
![[51.JPG]](https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEgSMPUlOIoCZrr1C0AWBeVQAz8XInvjOAwsPdT4FTDrGkYrd2T9SYVSVaLqJomTcM4wGcNbkfuUHyhG_WlmUnJxGPEhdcxDjCXJTcECpsTl6kQ8JlIf0LX1HrfElNOXiaxZXNYYGBGtawk/s1600/51.JPG)
(Keadaan awal merupakan
lanjutan gambar sebelumnya)
![[52.JPG]](https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjaahSHvzcaqIrigQ4wrdMIafQF7H30jYRPVJLYrn-plOc1NnGaF3_H0eX6tRSU5YOIKJUdwYM6BdbTlAMRy_TdzNpvWIB41ATwl1NP_faw4J2CLNCgIws6PQj1S_3kBYzTE4jRpLEknT0/s1600/52.JPG)
Pada operasi di samping, delete dilakukan
terhadap Node dengan 2 child. Maka untuk menggantikannya, diambil node paling
kiri dari Right SubTree yaitu 13.
![[53.JPG]](https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjoVS76haRJXdWEHBX1JFqZntNkfw1vr0RWSYSbLFgSILCvukH1R7tOkmsCjOMsocjhijjoD0AoESXvpQ-H9KUM-BW8lufWtriunVWDNrHRxGjRbRxRF0urC8BPyUpHylDrcb8cWD7e4xc/s1600/53.JPG)
Tidak ada komentar:
Posting Komentar