1 / 45

LINK LIST

LINK LIST. Latifah Rifani. SEJARAH. Dikembangkan tahun 1955-1956 oleh Allen Newell, Cliff Shaw dan Herbert Simon di RAND Corporation sebagai struktur data utama untuk bahasa Information Processing Language (IPL). IPL dibuat untuk mengembangkan program artificial intelligence.

martha
Download Presentation

LINK LIST

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. LINK LIST LatifahRifani

  2. SEJARAH • Dikembangkan tahun 1955-1956 oleh Allen Newell, Cliff Shaw dan Herbert Simon di RAND Corporation sebagaistruktur data utamauntukbahasa Information Processing Language (IPL). IPL dibuatuntukmengembangkan program artificial intelligence

  3. PENGENALAN • List merupakansebuahpemikiran/konsepstruktur data yang sangatdasarpadapemrograman agar lebihfleksibel. • Setiapelemenakanditambahkansaatdibutuhkan, tidakdialokasikandengantempattertentudariawal.

  4. ILUSTRASI Secaralogika, kepalaatau first adalahpengaitataupenunjukawalelemenpertamadarisebuah list. kepala null Gambar list dengantigabuahelemen

  5. PENGERTIAN • Merupakansekumpulanelemen list yang bertipesama. • Elemen list mempunyaiketerurutantertentu, nilaisatuelemenbolehmuncullebihdarisatu kali. • Setiapelemenmempunyai 2 bagian: • Informasielemen • Alamatsuksesornya

  6. Linked List adalah salah satu bentuk struktur data, berisi kumpulan data (node) yang tersusun secara sekuensial, saling sambung-menyambung dan dinamis. • Linked List saling terhubung dengan bantuan variabel pointer. • Masing-masing data dalam Linked List disebut dengan node (simpul) yang menempati alokasi memori secara dinamis.

  7. Setiap node terdiriatasduabagian. Bagianpertamaberisiinformasi data tersebut, • Bagiankeduamerupakan field, link, ataunextpointer. Link inilah yang menghubungkansatuelemen data keelemen data lainnya, sehinggaurutanelemen data tersebutmembentuksuatu linear list.

  8. Field link iniberisialamatdarisimpulberikutnyadalam list. • Field link bernilai 0 bila link tersebuttidakmenudingke data (simpul) lainnya. • Penudinginidisebutpenuding nol.

  9. ILUSTRASI NEXT ELEMEN NODE A B C LINK LIST

  10. CONTOH • Misalnyakitainginmembuatsebuahelemen data nilaimahasiswa yang terdiridari NRP, nama, dannilai, makarepresentasinyaadalahsebagaiberikut: NRP nama nilai next 94410 iffa A Penunjukkeelemenberikutnya

  11. Bilaelemensepertidiatasdibuatdalambahasaalgoritma, sepertiberikut: type nilaiMatKul : < NRP : string, nama : string, nilai : string, > • Elemenditambahdenganpengait/penunjuk: type elemen : < elmt : nilaiMatKul, next : elemen >

  12. Deklarasilistnyasebagaiberikut: type list : < first : elemen >

  13. Penunjukelemen di awalini (first) digunakanuntukmemegangelemenawalsebuah list agar dapatdiaksessatu per satusampaielementerakhir list. • Sebuahstruktur data yang dianggapsebagai list memilikiaturanpengaksesan. • Pengaksesandilakukandaripenunjukelemenpertama (first) kemudianberjalanmajukeelemenkedua, ketigadanseterusnyasampaielementerakhir.

  14. KEUNTUNGAN LIST • Penggunaanmemori yang dinamik. • Kita dapatmengaturpenggunaanmemorisehinggabisalebihhemat. • Kesederhaanpada proses insert dan delete elemen.

  15. Alamatelemenpertamadarisuatu list, dapatdiacuoleh First(L). • Nilai yang dibawanyadapatdiacudengan info(P)

  16. 10 15 20 10 15 20 head head prev next JENIS LINK LIST • Single Linked List dapatjugaditulisNULL • Double Linked List

  17. 10 10 15 20 data pointer NULL PENGERTIAN • Single : artinya field pointer-nya hanya satu buah saja dan satu arah serta pada akhir node, pointernya menunjuk NULL • Linked List : artinya node-node tersebut saling terhubung satu sama lain.

  18. 15 20 10 data pointer NULL • Setiap node pada linked list mempunyai field yang berisipointerke node berikutnya, danjugamemiliki field yang berisidata. • Node terakhirakanmenunjukkeNULL yang akandigunakansebagaikondisiberhentipadasaatpembacaanisi linked list.

  19. 10 15 20 10 15 20 head head tail JENIS SINGLE LINK LIST Single Link List dengan Head Single Link List dengan Head dan Tail

  20. BEBERAPA OPERASI PADA LIST

  21. MEMBUAT ELEMEN LINKED LIST • Membuatsuatuelemen linked list berartimemesantempat di memoriuntukmenyimpansebuah list.

  22. MENGHAPUS ELEMEN LIST • Menghapuselemen list berartimenghilangkanataumenghancurkanalokasimemorisebuah list yang telahada di memori. • Fungsi: agar data yang tidakdiperlukanbenar-benarterhapus di memorisehinggapenggunaanmemoridapatoptimal karena data-data yang tidakdiperlukandihilangkan.

  23. PENAMBAHAN ELEMEN DI POSISI AWAL • Penambahanelemen di posisiawaladalahmenambahkan data barupadaposisiawal, sehingga data barutersebutakanmenjadiawal. • Ada 2 hal yang harusdiperhatikan, yaitu : • kondisi linked list sedangkosong, atau • kondisilinked list sudahmempunyaielemen.

  24. Kondisi Linked List SedangKosong • Ketikalinked list masihkosong, maka variable awaldanakhirakandiisidengan variable baru.

  25. 10 head head 1. List masihkosong (head=NULL) NULL 2. Masukkan data baru, misal 10

  26. Kondisi Linked List SudahMempunyaiElemen. • Proses penambahannyaadalahdenganmengisikanfield next milikelemenbarudenganposisiawal linked list, kemudianposisiawalberubahkeposisibaru.

  27. 10 15 15 10 15 10 head baru head head baru Masukkandata barudaridepan, misal 15

  28. PenambahanElemen Di PosisiTerakhir • Penambahan di posisiakhiradalah proses penambahan data barudimana data barudisimpan di posisiterakhir. • Setelahproses penambahanselesai, makavariable akhirakanmenunjukke data barutersebut. • Ada 2 halyang harusdiperhatikanyaitu : • Kondisipenambahanakhirpada linked list yang masihkosongdan • Kondisipenambahanakhirpada linked list yang sudahmempunyaielemen.

  29. 10 15 10 15 10 15 bantu head head baru head baru Masukkandata barudaribelakang, misal 15

  30. 21 21 15 21 10 15 10 10 15 bantu head baru baru head head Masukkandata barudaribelakang, misal 21

  31. MENAMPILKAN SINGLE LINKED LIST DENGAN HEAD • Penelusuraninidilakukandenganmenggunakansuatupointer bantu, karenapadaprinsipnya pointer head yang menjaditandaawal list tidakbolehberubah/bergantiposisi. • Penelusurandilakukanterussampai node terakhirditemukanmenunjukkenilai NULL. Jikatidak NULL, maka node bantu akanberpindahke node selanjutnyadanmembacaisidatanyadenganmenggunakan field next sehinggadapatsalingberkait. • Jika head masih NULL berarti data masihkosong!.

  32. Contoh: Langkah-langkahpenelusuranadalah : • ƒIsi variable p denganawal. • ƒSelamap tidak NULL, makatampilkan info yang ada di elemen yang ditunjukvariable p, kemudian p dipindahkankeelemenberikutnya.

  33. PENGHAPUSAN DATA AWAL • Penghapusan data di awaladalah proses menghapuselemenpertama (awal), sehinggavariable awalakanberpindahkeelemen data berikutnya. • Ada 3 kondisiyang perludiperhatikanyaitu: • kondisilinked list masihkosong • kondisilinked list hanyamemiliki 1 data, dan • kondisilinked list yang memiliki data lebihdari 1 elemen.

  34. Kondisilinked list masihkosong • Padakondisiini proses penghapusantidakbisadilakukan. • Kondisilinked list hanyamemiliki 1 data • Langkah yang dilakukanadalahmenghapus data yang ada di posisiawalkemudianakhirdanawal di-NULL-kan.

  35. Kondisi linked list memiliki data lebih dari 1 data: • Alamatdata awaldiisikankesuatuvariabelpembantu (phapus). • Setelahitupindahkanawalke data berikutnya. • Setelahituhapus/hancurkan data di posisiphapus.

  36. 21 21 10 15 15 head head Proses penghapusan data 10 daridepan

  37. Penghapusannode tidakbolehdilakukanjikakeadaan node sedangditunjukoleh pointer. • Sebelum data terdepandihapus, head harusditunjukkanke node sesudahnyaterlebihdahulu agar list tidakputus, sehingga node setelah head lama akanmenjadi head baru (data terdepan yang baru).

  38. PENGHAPUSAN DATA AKHIR • Penghapusan data akhiradalah proses menghilangkan/menghapus data yang adadi posisiterakhir. • Ada 3 kondisi yang harusdiperhatikanketikaakanmelakukanproses penghapusan data akhiryaitu: • Kondisilinked list masihkosong, • Kondisi linked list hanyaberisi 1 data, dan • Kondisilinked list berisi data lebihdari 1 buah.

  39. 10 15 15 10 34 10 15 34 21 21 21 head bantu hapus head head bantu bantu Proses menghapus data 34 dari belakang

  40. MENGHAPUS DATA DARI BELAKANG • Membutuhkanpointer bantu danhapus. • Pointer hapusdigunakanuntukmenunjuk node yang akandihapus, dan pointer bantu digunakanuntukmenunjuk node sebelum node yang dihapus yang kemudianselanjutnyaakanmenjadi node terakhir. • Pointer bantu akan digunakan untuk menunjuk ke nilai NULL. • Pointer bantu akan selalu bergerak sampai sebelum node yang akan dihapus, baru kemudian pointer hapus diletakkan setelah pointer bantu. Setelahitu pointer hapusakandihapus, pointe bantu akanmenunjukke NULL.

  41. 10 15 20 head tail • Dibutuhkanduabuahvariabel pointer: headdantail • Head akanselalumenunjukpada node pertama, sedangkan tail akanselalumenunjukpada node terakhir.

  42. IMPLEMENTASI LIST MENGGUNAKAN JAVA

  43. Java tidakmemiliki pointer namunmemiliki reference. • Reference adalahpenunjukkeobjek (fungsinyasamaseperti pointer)

  44. CONTOH: • Contohpenggunaan reference: Data a = new Data(); Data b = a; /* b menunjukke a*/ • Jika b di ubah, maka a jugaakanberubah

  45. ELEMEN LIST • Pada java, elemen list didefinisikandengankelas. Jadielemen list adalahkelas. • Suatukelasbolehmereferdirinyasendiri. • Contoh: class ListElement { String info; ListElement next; }

More Related