program single linked list

Upload: daniel-nainggoland

Post on 05-Apr-2018

215 views

Category:

Documents


0 download

TRANSCRIPT

  • 7/31/2019 Program Single Linked List

    1/4

    Program singlelinkedlist ;

    uses wincrt;

    Type

    Pointer = ^TypeData;

    TypeData = Record

    Nilai : integer;Berikutnya : Pointer;

    End;

    Var

    List : Pointer;

    Procedure Masuk_Depan(Var L : Pointer; X : Integer);

    Var

    Baru : Pointer;

    Begin

    New(Baru);

    Baru^.Nilai := X;Baru^.Berikutnya := Nil;

    if L = Nil then L := Baru

    else

    Begin

    Baru^.Berikutnya :=L;

    L :=Baru;

    End;

    End;

    Procedure Sisip_Tengah(Var L : Pointer; X, Y : Integer);

    Var

    Baru,Bantu : Pointer;

    Begin

    Bantu := L;

    While Bantu^.berikutnya Nil Do

    Begin

    If Bantu^.Nilai = X Then

    Begin

    New(Baru);

    Baru^.Nilai := Y;

    Baru^.Berikutnya := Bantu^.Berikutnya;

    Bantu^.Berikutnya := Baru;

    End;

    Bantu := Bantu^.Berikutnya;

    End;

    End;

    Procedure Masuk_Belakang(Var L : Pointer; X : Integer);

    Var

  • 7/31/2019 Program Single Linked List

    2/4

    Baru,Bantu : Pointer;

    Begin

    New(Baru);

    Baru^.Nilai := X;

    Baru^.Berikutnya := Nil;

    Bantu := L;While Bantu^.Berikutnya Nil Do

    Bantu := Bantu^.Berikutnya;

    Bantu^.Berikutnya := Baru;

    End;

    Procedure Hapus_Depan(Var L : Pointer);

    Var

    Baru : Pointer;

    Begin

    Baru := L;

    if L = Nil then Writeln('List Kosong...')else

    Begin

    L := L^.Berikutnya;

    dispose(Baru);

    End;

    End;

    Procedure Hapus_Tengah(Var L : Pointer; X : Integer);

    Var

    Bantu,Hapus : Pointer;

    Begin

    Bantu := L;

    if L = Nil then Writeln('List Kosong...')

    else

    Begin

    Bantu := L;

    New(Hapus);

    While Bantu^.Berikutnya nil Do

    Begin

    if Bantu^.Berikutnya^.nilai = X then

    begin

    Hapus:=Bantu^.Berikutnya;

    Bantu^.Berikutnya:=Hapus^.Berikutnya;

    dispose(Hapus);

    End

    else

    Bantu:=Bantu^.Berikutnya;

    End;

    End;

  • 7/31/2019 Program Single Linked List

    3/4

    End;

    Procedure Hapus_Belakang(Var L : Pointer);

    Var

    Baru,bantu : Pointer;

    BeginBantu := L;

    if Bantu = Nil then Writeln('List Kosong...')

    else

    Begin

    While Bantu^.Berikutnya^.Berikutnya nil do

    Bantu := Bantu^.berikutnya;

    New(Baru);

    Baru := Bantu^.Berikutnya;

    Bantu^.Berikutnya:=nil;

    dispose(Baru);

    End;end;

    Procedure Cetak(L : Pointer);

    Var

    Bantu : Pointer;

    Begin

    Bantu := L;

    While Bantu Nil Do

    Begin

    Write(Bantu^.Nilai:3);

    Bantu:=Bantu^.Berikutnya;

    End;

    End;

    Var

    Bil,Bil1 : integer;

    JB : Char;

    Begin

    New(List);

    List:=nil;

    Jb := 'Y';

    Writeln('MASUK DEPAN');

    While UpCase(Jb)='Y' Do

    Begin

    Write('Masukkan Bilangan : '); Readln(Bil);

    Masuk_Depan(List,Bil);

    Write('Lagi[Y/T] ');Readln(Jb);

    End;

    Cetak(List);

  • 7/31/2019 Program Single Linked List

    4/4

    Writeln;

    Jb := 'Y';

    Writeln('MASUK BELAKANG');

    While UpCase(Jb)='Y' Do

    Begin

    Write('Masukkan Bilangan : '); Readln(Bil);Masuk_Belakang(List,Bil);

    Write('Lagi[Y/T] ');Readln(Jb);

    End;

    Cetak(List);

    writeln;

    Jb := 'Y';

    Writeln('MASUK DEPAN');

    While UpCase(Jb)='Y' Do

    Begin

    Write('Masukkan Bilangan : '); Readln(Bil);

    Masuk_Depan(List,Bil);Write('Lagi[Y/T] ');Readln(Jb);

    End;

    Cetak(List);

    Writeln;

    Writeln('SISIP TENGAH');

    Write('Masukkan Bilangan Yg akan disisip : ');

    Readln(Bil1);

    Write('Disisip Setelah Bilangan : ');

    Readln(Bil);

    Sisip_Tengah(List,Bil,Bil1);

    Cetak(List);

    Writeln;

    writeln('HAPUS DEPAN ');

    Hapus_Depan(List);

    Cetak(List);

    Writeln;

    writeln('HAPUS BELAKANG');

    Hapus_Belakang(List);

    Cetak(List);

    Writeln;

    Writeln('HAPUS TENGAH');

    Write('Masukkan Bilangan Yg akan dihapus : ');

    Readln(Bil);

    Hapus_Tengah(List,Bil);

    Cetak(List);

    Writeln;

    End.