Langsung ke konten utama

Program Binery Tree Mengunakan Pascal


Binery Tree
Pohon (tree) merupakan struktur data tak linier yang mempunyai sifat-sifat dan ciri-ciri khusus. Struktur ini biasanya digunakan untuk menggambarkan hubungan yang bersifat hirarki antara elemen-elemen yang ada. 
Pohon biner (binary tree) bisa didefinisikan sebagai suatu kumpulan simpul yang mungkin kosong atau mempunyai akar dan dua sub pohon yang saling terpisah yang disebut dengan subpohon kiri (left subtree) dan sub pohon kanan (right subtree). Sub pohohn juga disebut dengan cabang. Karakteristik yang dimiliki oleh pohon biner adalah bahwa setiap simpul paling banyak hanya mempunyai dua bauh anak. Dengan kata lain, derajat tertinggi dari setiap simpul dalam pohon adalah dua. Karakteristik yang lain adalah pohon biner dimungkinkan tidak mempunyai simpul.


Jenis-jenis Binery Tree:
         Full Binery Tree
Binery Tree yang tiap nodenya (kecuali left) memiliki dua child dan tiap subtree harus mempunyai panjang path yang sama.



      Complete Binery Tree
Mirip dengan Full Binery, namun tiap subtree boleh memiliki panjang path yang berbeda. Node kecuali leaf memiliki 0 atau 2 child.


        Skewed Binery Tree
Yakni Binery Tree yang semua nodenya (kecuali left) hanya memiliki satu child


Mendeklarasikan Struktur Pohon Biner
Setiap simpul pada pohon terdiri 2 komponen utama:
         Data
         Pointer yang menunjuk ke anak
Pointer anak ada 2 macam, yaitu:
         Pointer yang menunjuk ke anak kiri
           Pointer yang menunjuk ke anak kanan

 Insert : Memasukan sebuah node ke dalam tree. Ada tiga pilihan insert: sebagai root, left chile, right chile. Khusus insert sebagai root, tree harus dalam keadaan kosong

Implementasi: 12 9 15 5 13 11 20




Delete : Menghapus subtree (node beserta seluruh descen datanya) yang ditunjuk current. Tree tidak boleh kosong. Setelah itu pointer current akan berpindah ke parent dari node yang di hapus.

Implementasi: 12 9 15 5 13 11 20

 Finding : Mencari root, parent, left chile, atau right chile dari suatu node. (tree tidak boleh kosong)
Implementasi : mencari angka yang terdapat di pohon biner. Maka ketemu angka 11


Traverse : Mengunjungi seluruh node-node pada tree, masing masing sekali. Hasilnya adalah urutan informasi secara linier yang tersimpan dalam tree.
Ada tiga cara traverse : Pre Order, In Order, dan Post Order.
Langkah-langkah Treverse:
·         PreOrder   : cetak isi node yang di kunjungi, kunjungi left chile, kunjungi right chile.
Implementasi   : B A A E I J R



·         InOrder     : kunjungi left chile, cetak isi node yang di kunjungi, kunjungi right chile.

Implementasi   : A A B E J L R




·         PostOrder : kunjungu left chile, kunjungi right chile, cetak isi node yang di kunjungi.

Implementasi   : A A J R L E B

 


Program Binery Tree

uses crt;

type

pointer = ^ptr;

ptr = record
        isi :byte;
        kiri,kanan:pointer;
        end;
var
        x,y, sel, pil : byte;
        tree, root, Now : pointer;
procedure create;
        begin
                root:=nil; tree:=nil;
        end;
procedure clear;
        begin

           if root <> nil then
           begin
           tree:=root; dispose(tree); root:=nil;
           end;
        end;
procedure push (var tree: pointer; bil:byte);
        begin
                if tree=nil then
                begin
                new(tree);
                tree^.isi :=bil;
                tree^.kiri :=nil;
                tree^.kanan :=nil;
                end
                else
                if tree^.isi < bil then
                push(tree^.kanan,bil)
                else
                push(tree^.kiri,bil)
        end;
Procedure find(var ketemu:boolean; tree:pointer; angka:byte);
        begin
                ketemu:=false;
                if tree<>nil then
                        begin
                                if tree^.isi=angka then
                                begin
                                         ketemu:=true; exit;
                                end;
                                find(ketemu,tree^.kiri,angka);
                                if not ketemu then
                                find(ketemu,tree^.kiri,angka);
                        end;

        end;
procedure show (var tree:pointer; x, y, sel:byte);
        var i:byte;
        begin
                gotoXY(x,y); write(tree^.isi);
                        if (tree^.kiri <> nil) or (tree^.kanan <> nil) then
                        begin
                gotoXY(x-sel,y+1); write ('*');
                gotoXY(x+sel,y+1); write ('*');
                for i:=(x-sel)+1 to (x+sel)-1 do
                        begin
                                gotoXY(i,y+1); write('-');
                        end;
                gotoXY(x,y+1); write ('~');
        end;

        inc(y,2);
        if tree^.kiri <> nil then show(tree^.kiri, x-sel, y, sel div 2);
        if tree^.kanan <> nil then show(tree^.kanan, x+sel, y, sel div 2)
end;
procedure checklevel (var tree:Pointer; var level:byte; bil:byte);
        begin
                if tree<>nil then
                begin
                        inc(level);
                        if tree^.isi < bil then
                                checklevel (tree^.kiri,level,bil)
                                else
                                checklevel (tree^.kanan,level,bil);
                end;
                end;
procedure           preorder(tree:pointer);
begin
if tree<> nil then
begin
        gotoXY(x,y);write(tree^.isi);   inc(x,3);
        Preorder(tree^.kiri);
        preorder(tree^.kanan);
        end;
end;
procedure           inorder(tree:pointer);
begin
if tree<> nil then
begin
        inorder(tree^.kiri);
        gotoXY(x,y);write(tree^.isi);   inc(x,3);
        inorder(tree^.kanan);
        end;
end;
procedure           postorder(tree:pointer);
begin
if tree<> nil then
begin
        Postorder(tree^.kiri);
        postorder(tree^.kanan);
        gotoXY(x,y);write(tree^.isi);   inc(x,3);
        end;
end;
procedure insert;
var
        isi, level :byte;
        ketemu : boolean;
        begin
                repeat
                clrscr;
                        writeln('insert binary');
                        writeln('*+*+*++*+*+*+');
                        if root<> nil then show (root,40,5,20);
                        repeat
                                gotoXY(3,4); clreol; write ('insert [level max:5] =');
                                readln(isi);
                        until isi in [0..100];
                        if isi=0 then exit;
                        level:=1;
                        checklevel(root, level, isi);
                        find(ketemu,root,isi);
                        if (not ketemu) and (level<=5) then
                                push(root,isi)
                        else
                        begin
                                textcolor(12);
                                GotoXY(3,5); write('level maksimum/bil sudah ada');
                                delay(750);
                                textcolor(15);
                        end;
                until isi=0;
        end;
procedure hapus(var tree:pointer; bil:byte);
var temp:pointer;
begin
        if tree=nil then
        begin
                textcolor(12); gotoXY(2,4); write(bil,'tidak ada');
                textcolor(15);
        end else
                if bil< tree^.isi then
                        hapus(tree^.kiri,bil)
                else if bil> tree^.isi then
                        hapus(tree^.kanan,bil)
                else if tree^.kiri= nil then
                begin
                        temp:=tree^.kanan;
                        dispose(tree);
                        tree:=temp;
                end
                else if tree^.kanan= nil then
                begin
                        temp:=tree^.kiri;
                        dispose(tree);
                        tree:=temp;
                end  else
                        begin
                                temp:=tree^.kiri;
                                while temp^.kanan <> nil do
                                temp:=tree^.kanan;
                                tree^.isi := temp^.isi;
                                hapus (tree^.kiri,temp^.isi);
                        end
                end;
        procedure search(var tree:pointer; x,y,selisih,cari:byte);
        begin
                inc(y,2);
                if cari
                begin
                        if tree^.kiri <> nil then
                        search(tree^.kiri, x-selisih, y, selisih div 2, cari)
                end else
                if cari > tree^.isi then
                begin
                        if tree^.kanan <> nil then
                        search(tree^.kanan, x+selisih, y, selisih div 2, cari)
                end else
                if cari = tree^.isi then
                begin
                        dec(y,2);
                        gotoxy(x,y); textcolor (12); write (cari);
                        gotoxy(2,4); write (cari,'ketemu'); readkey;
                        gotoxy(x,y); textcolor (15); write (cari);
                        gotoxy(2,4); write (' ':20);
                end else
                if ((tree^.kiri=nil) or (tree^.kanan=nil)) and
                (cari <> tree^.isi) then
                begin
                        gotoxy(2,4); write (cari,'tidak ketemu'); delay(750);
                        gotoxy(x,y); write (' ':20);
                end;
        end;
                procedure menu;
                var
                bil    :byte;
                sign:char;
                ketemu:boolean;
                begin
                clrscr;
                        writeln('Menu pohon biner');
                        writeln('1. create');
                        writeln('2. tambah');
                        writeln('3. hapus');
                        writeln('4. cari');
                        writeln('5. traverse');
                        writeln('6. Bersih');
                        writeln('7. exit');
                        repeat
                        write ('pilih anda 1...7 :');
                        readln (pil);
                        until pil in [1..7];
                        case pil of
                        1: create;
                        2: insert;
                        3: begin
                         repeat
                         clrscr;
                         write ('hapus pohon biner');

                         if root <> nil then show  (root, 40,5,20);
                         gotoXY (2,3); write ('delet [0-->exit] = ');
                         readln ( bil);
                         hapus(root,bil);
                         until bil=0;
                         end;
                         4: begin
                                repeat
                                        clrscr;
                                        gotoxy(30,1); writeln('cari pohon biner');
                                        gotoxy(27,2); writeln('------');
                                        if root <>nil then show(root,40,5,20);
                                        gotoxy(2,3); write('cari [0-->keluar]= ');
                                        readln(bil);
                                        if bil <> 0 then search(root,40,5,20,bil);
                                        until bil=0;
                            end;
                         5: begin
                                clrscr;
                                gotoxy(25,1); writeln('traverse');
                                if root<>nil then show(root,40,5,20);
                                gotoxy(36,15); writeln ('pre order :');
                                gotoxy(25,16);

writeln ('_______________________');
                                x:=1;y:=17;preorder(root);
                                gotoxy(36,18); writeln ('in order :');
                                gotoxy(25,19);
writeln ('______________________');
                                x:=1;y:=20;inorder(root);
                                gotoxy(36,21); writeln ('post order :');
                                gotoxy(25,22);
`           writeln ('_____________________');
                                x:=1;y:=23;preorder(root);    readkey;
                         end;
                         6: begin
                                clear;
                                create;
                             end;
                         7: Exit;
                         end;
                         end;

        begin
        textcolor(15);
        repeat
        menu;
        until pil=7;
        clear;
        end.

Referensi :

1.Dwi Sanjaya, 2001, Bertualang dengan Struktur Data di Planet Pascal, J & J Learning, Yogyakarta
2.M. Hasbi, 2003, Struktur Data dan Algoritma dalam Pemograman Turbo Pascal, Grava Media, Yogyakarta
 







Komentar

Postingan populer dari blog ini

Cara membuat logo adidas 3D menggunakan CorelDraw

Pada kesempatan kali ini kami akan mengulas bagaimana caranya membuat logo adidas 3D menggunakan CorelDraw X5. Untuk membuat logo adidas pastikan komputer anda sudah terinstal CorelDraw terlebih dahulu.  Langkah Pertama, klik menu star kemudian pilih CorelDraw gambar 1.1 Langkah Kedua, setelah anda pilih CorelDraw maka akan muncul tampilan seperti di bawah ini. Pilih New blank document untuk masuk ke halaman kerja. gambar 1.2 Langkah Ketiga, atur area kerja sesuai kebutuhan anda seperti nama halaman kerja, panjang dan lebar kertas, setelah di atur kemudian klik OK. gambar 1.3 Langkah Keempat, maka akan tampil halaman kerja CorelDraw X5 gambar 1.4 Langkah Kelima, buat object persegi panjang dengan ukuran 1 x 5 cm, kemudian miringkan object dengan kemiringan 40 derajat. gambar 1.5 Langkah Keenam, melakukan penggandaan object dengan menekan "Ctrl+D" atau dengan mengcopy. Selanjutnya susunlah object seperti pada gambar di bawah, k...

Konsepsi Wahyu

Menurut Bahasa adalah sesuatu yang tersembunyi. Sedangkan menurut istilah adalah   pemberitahuan secara tersembunyi dan cepat yang diberikan kepada orang khusus (Nabi dan Rosul) tanpa di ketahui orang lain. Nama lain dari Wahyu antara lain : 1. Al-Ilham al-fithri li al-insan وَأَوْحَيْنَا إِلَى أُمِّ مُوسَى أَنْ أَرْضِعِيهِ فَإِذَا خِفْتِ عَلَيْهِ فَأَلْقِيهِ فِي الْيَمِّ وَلا تَخَافِي وَلا تَحْزَنِي إِنَّا رَادُّوهُ إِلَيْكِ وَجَاعِلُوهُ مِنَ  الْمُرْسَلِينَ “Dan kami ilhamkan kepada ibu Musa. “Susuilah dia, dan apabila kamu khawatir terhadapnya maka jatuhkanlah dia ke sungai (Nil). Dan janganlah kamu khawatir dan janganlah pula bersedih hati, karena sesungguhnya kami akan mengembalikanya kepadamu, dan menjadikanya (salah seorang) dari para rasul.” (Q.S. Al-Qashash:7).             Wahyu dalam ayat di atas berarti ilham yang diberikan Allah SWT kepada Ibu Musa untuk meyusukan bayinya yang dihanyutkan kesungai ...

Vestival HUT Ke-70 RI

Vestival dan Lomba Memperingati HUT Ke-70 Republik Indonesia