Apa itu Linked list ?
Linked list adalah sejumlah simpul (node) yang dikaitkan dengan simpul yang lain dengan bantuan pointer dalam suatu urutan tertentu. Suatu linked list dikatakan single linked list apabila hanya ada satu pointer yang menghubungkan setiap node (satu arah “next”).
Linked list adalah sejumlah simpul (node) yang dikaitkan dengan simpul yang lain dengan bantuan pointer dalam suatu urutan tertentu. Suatu linked list dikatakan single linked list apabila hanya ada satu pointer yang menghubungkan setiap node (satu arah “next”).
Single linked list dapat dibagi menjadi:
Single linked list non circular
Single Linked List yang pointer next pada node terakhir(tail) -nya menunjuk ke Null.
1. Deklarasi node dengan struct pada single linked list:
struct tnode
{
int data;
struct tnode *next;
}
struct tnode
{
int data;
struct tnode *next;
}
Gambar Sebuah Node pada Single Linked List |
2. Deklarasi node untuk beberapa keperluan, seperti berikut ini:
struct tnode *head=NULL, *curr=NULL, *node=NULL;
3. Membuat elemen pertama dan menambahkan elemen di belakang Single Linked List
Single Linked List yang pointer next-nya menunjuk ke dirinya sendiri, jika terdiri dari beberapa node maka pointer terakhirnya(tail) akan menunjuk ke pointer terdepannya(head).
1. Deklarasi Single Linked List Circular:
struct tnode
{
int data;
tnode *next;
};
void main()
{
head = new tnode;
head->next = head;
}
2. Menambah node dan membuat tail dari single linked list circular
Deklarasi penambahan node baru:
void main()
{
node = new tnode;
tail = new tnode;
//head->next di bawah ini "masih" menunjuk ke head itu sendiri
//jadi, kode di bawah ini maksudnya node->next menunjuk ke head
node->next = head->next;
//baru di sini head->next diubah menunjuk ke node
//hasilnya akan seperti "Gambar 6"
head->next = node;
tail = node;
}
3. Deklarasi menyisipkan node baru menggunakan sintak berikut:
void main()
{
node = new tnode;
node->next = head->next;
head->next = node;
}
Gambar Menyisipkan Node Baru |
4. Deklarasi menghapus node dari single linked list circular, menggunakan sintaks berikut:
void main()
{
hapus = new tnode;
if( head != tail)
{
hapus = head;
head = head->next;
tail->next = head;
delete hapus;
}else
{
head = NULL;
tail = NULL;
}
}
Contoh Program Single linked list :