Tuesday, July 27, 2010

Single Linked List Pada Java

Linked List merupakan salah satu struktur data yang sangat fundamental dalam bidang ilmu komputer. Dengan menggunakan linked list, rogramer dapat menyipan datanya kapanpun dia mau. Linked list mirip dengan array, kecuali pada linked list data yang ingin disimpan dapat dialokasikan secara dinamis pada saat pengoprasian program.

Linked list ada 3 yaitu single linked list, double linked list, dan circular linked list. Di bawah ini merupakan contoh program sederhana dari single link list. Untuk hasil dari program ini adalah sebagai berikut : 

dan Untuk Source Codenya adalah sebagai berikut :

import java.util.Scanner;

class X{
    int data;
    X next;
   
    X(int input){
        this(input, null);
    }
   
    X(int input, X node){
        data = input;
        next = node;
    }
}

class list1{
    private X awal;
    private X akhir;
    private int bil;
   
    public list1(){
        this (0);
    }
   
    public list1(int datalist){
        bil = datalist;
        awal = akhir = null;
    }
   
    public boolean kosong(){
        return awal == null;
    }
   
    public void tambahdata(int input){
        if (kosong()){
            awal = akhir = new X(input);
        }
       
        else{
            akhir = akhir.next = new X(input);
        }
    }
   
    public void cetakLinked(){
        System.out.println ("Data yang ada di linked list adalah :");
        X cetak = awal;
        while (cetak!=null){
            System.out.print (cetak.data+" ");
            cetak = cetak.next;
        }
    }
}

public class Linked{
    public static void main (String[] args) {
        Scanner input = new Scanner(System.in);
            System.out.println ("Program single linked list");
            System.out.println ("");
           
            list1 xx = new list1();
            int data;
            System.out.print ("Masukan Jumlah Data :");
            int jml = input.nextInt();
           
            for (int i=0; i
                System.out.print ("Masukkan Data ke-"+(i+1)+" :");
                data = input.nextInt();
                xx.tambahdata(data);
            }
           
            System.out.println ("");
            xx.cetakLinked();
            System.out.println ("");
           
            boolean terus = false;
            while(!terus){
                System.out.print ("Ingin Tambah Data(Y/T) :");
                String jawab = input.next();
                char A = jawab.charAt(0);
                if ((A == 'T')||(A == 't')){
                    terus = true;
                }
                else{
                    System.out.print ("Tambah Berapa Data :");
                    int jml2 = input.nextInt();
                    System.out.println ("");
                    for (int i=0; i< jml2; i++){
                    System.out.print ("masukan data ke-"+(i+1+jml)+" :");
                    data = input.nextInt();
                    xx.tambahdata(data);
                    }
                    jml=jml+jml2;
                    System.out.println ("");
                    xx.cetakLinked();
                    System.out.println ("");
                }
            }
           
            System.out.println ("");
            xx.cetakLinked();
}
}

Supaya lebih jelas bisa didowload disini : DOWNLOAD

0 comments:

Post a Comment