Dalam istilah ilmu komputer, struktur data adalah cara menyimpan dan mengatur data secara terstruktur pada sistem komputer atau pangkalan data (database) sehingga lebih mudah diakses. Secara teknis, data dalam bentuk angka, huruf, simbol, dan lainnya ini diletakkan dalam kolom-kolom dan susunan tertentu. Contoh struktur data dapat dilihat pada berkas-berkas lembar sebar (spreadsheet), pangkalan data, pengolah kata, citra yang dipampat (compressed image), dan pemampatan berkas dengan teknik tertentu yang memanfaatkan struktur data.

Dalam teknik pemrograman, struktur data berarti tata letak data yang berisi kolom-kolom data, baik itu kolom yang terlihat oleh pengguna ataupun kolom yang hanya digunakan untuk keperluan pemrograman yang tidak terlihat oleh pengguna. Setiap baris dari kumpulan kolom-kolom tersebut dinamakan catatan (record). Lebar kolom pada data bisa berubah-ubah. Ada kolom yang ukurannya dapat menyesuaikan secara otomatis berdasarkan input pengguna, dan ada juga kolom yang ukurannya tetap. Karena sifat tersebut, struktur data ini dapat digunakan dalam pengolahan basis data, seperti data keuangan, maupun pada aplikasi pengolah kata yang membutuhkan ukuran kolom yang fleksibel dan dinamis.

Penggunaan

sunting

Struktur data adalah basis dari tipe data abstrak. Tipe data abstrak mendefinisikan bentuk logis dari sebuah tipe data, sementara struktur data mengimplementasikan bentuk fisik dari tipe data tersebut.[1]

Masing-masing jenis struktur data yang berbeda cocok untuk penggunaan-penggunaan yang berbeda, dan beberapa jenis memang dispesialisakian untuk tugas tertentu. Contohnya, basis data relasional biasanya menggunakan indeks B-tree untuk data retrieval,[2] sedangkan implementasi kompilator biasanya menggunakan tabel hash untuk menemukan pengidentifikasi.[3]

Struktur data memberikan cara mengelola data yang banyak secara efisien untuk berbagai penggunaan, misalnya untuk basis data yang besar dan layanan pengindeksan internet. Biasanya, struktur data yang efisien adalah kunci untuk mendesain algoritme yang efisien. Beberapa metode desain formal dan bahasa pemrograman menekankan struktur data, bukan pada algoritma, sebagai faktor kunci dalam mengatur desain perangkat lunak. Struktur data bisa digunakan untuk mengatur penyimpanan dan pengambilan informasi yang disimpan baik di dalam memori utama maupun memori sekunder.[4]

Contoh

sunting

Ada banyak jenis struktur data, yang biasanya dibuat dari tipe data primitif yang lebih sederhana:[5]

  • Larik (bahasa Inggris: array) adalah serangkaian elemen dengan urutan tertentu, biasanya semua elemen memiliki tipe yang sama (tergantung bahasanya, masing-masing elemen bisa harus bertipe sama, atau bisa bertipe apa saja). Setiap elemen bisa diakses menggunakan indeks bilangan bulat yang menentukan elemen mana yang diminta. Implementasinya biasanya mengalokasikan word memori yang berdampingan untuk elemen-elemen larik (tapi tidak selalu harus begitu). Larik bisa punya panjang yang tetap ataupun resizable.
  • Senarai berantai (bahasa Inggris: linked list) (kadang disebut juga senarai) adalah koleksi linear yang terdiri dari elemen-elemen data berjenis apapun, yang disebut node, di mana setiap node memiliki sebuah nilai, serta menunjuk ke node berikutnya di senarai berantai. Keuntungan utama dari senarai berantai dibandingkan dengan larik, adalah nilai-nilainya bisa dimasukkan dan dikeluarkan secara efisien tanpa memindahkan sisa isi senarai. Namun, untuk operasi-operasi lain, seperti melakukan akses acak terhadap elemen tertentu, senarai lebih lambat dibandingkan dengan larik.
  • Record (disebut juga tuple atau struct) adalah struktur data agregat. Sebuah record adalah sebuah nilai yang berisi nilai-nilai lain, biasanya dengan banyak dan urutan nilai yang tetap serta diindeks menggunakan nama. Elemen-elemen record biasanya disebut field atau member.
  • Union adalah struktur data yang menentukan sejumlah tipe data yang boleh disimpan dalam instansinya, misalkan float atau long integer. Bebeda dengan record, yang misalnya bisa didefinisikan menampung sebuah float dan sebuah integer; union hanya menampung satu data pada suatu waktu. Ruang yang dialokasikan untuk union harus cukup untuk menampung tipe data terbesar anggotanya.
  • Tagged union (disebut juga variant, variant record, discriminated union, atau disjoint union) menampung field tambahan yang menandakan tipenya pada saat ini, agar meningkatkan keamanan tipe.
  • Objek adalah struktur data yang menampung field data, seperti record, dan juga mengandung metode yang mengoperasikan isi datanya. Sebuah objek adalah sebuah instansi dalam-memori dari sebuah kelas. Dalam konteks pemrograman berorientasi objek, record dikenal sebagai plain old data structure untuk membedakannya dengan objek.[6]

Data struktur lainnya yang umum digunakan, diantaranya adalah tumpukan (bahasa Inggris: stack), antrean (bahasa Inggris: queue), dan pohon (bahasa Inggris: tree).

Referensi

sunting
  1. ^ "Abstract Data Types". Virginia Tech - CS3 Data Structures & Algorithms.
  2. ^ Gavin Powell (2006). "Chapter 8: Building Fast-Performing Database Models". Beginning Database Design. Wrox Publishing. ISBNย 978-0-7645-7490-0.
  3. ^ "1.5 Applications of a Hash Table". University of Regina - CS210 Lab: Hash Table. Diarsipkan dari asli tanggal 2020-03-25. Diakses tanggal 2020-03-25.
  4. ^ "When data is too big to fit into the main memory". homes.sice.indiana.edu. Diarsipkan dari asli tanggal 2021-04-27. Diakses tanggal 2020-03-25.
  5. ^ Seymour, Lipschutz (2014). Data structures (Edisi Revised first). New Delhi, India: McGraw Hill Education. ISBNย 9781259029967. OCLCย 927793728.
  6. ^ Walter E. Brown (September 29, 1999). "C++ Language Note: POD Types". Fermi National Accelerator Laboratory. Diarsipkan dari asli tanggal 2016-12-03. Diakses tanggal 6 December 2016.

Pranala luar

sunting
  • Deskripsi dari Dictionary of Algorithms and Data Structures

๐Ÿ“š Artikel Terkait di Wikipedia

Pemilihan Member Single Original JKT48

Pemilihan Member Single Original JKT48 merupakan pemungutan suara untuk menentukan anggota pilihan yang berhak untuk ikut serta pada singel original grup

Cortis

2025-08-11. Ayu, Geumerie. "Profil Member CORTIS, Boy Group Baru BIGHIT Music yang Berkonsep Unik - Lombok Post". Profil Member CORTIS, Boy Group Baru BIGHIT

Carmen (penyanyi)

Juun, A-na, Yuha, I-an, Stella, dan Ye-on. Carmen merupakan satu-satunya member non Korea. Debut perdana Hearts2Hearts ditandai dengan perilisan lagu berjudul

Pemilihan Member Single ke-6 JKT48

Pemilihan Member Single ke-6 JKT48 merupakan pemungutan suara untuk menentukan anggota pilihan yang berhak untuk ikut serta pada singel ke-6 grup idola

Stella

Diakses tanggal 2025-05-19. Khoiriyah, Nafi. "Profil Stella Hearts2Hearts, Member Asal Korea-Kanada". POPBELA.com. Diakses tanggal 2025-05-19. developer,

Sapnap

konten Minecraft -nya. Bersama dengan Dream dan GeorgeNotFound, Ia merupakan member dari Dream Team dan merupakan anggota pendiri server Dream SMP Minecraft

Pemilihan Member Single ke-26 JKT48

Pemilihan Member Single ke-26 JKT48 adalah sebuah rangkaian kegiatan pemilihan pada tahun 2024 dari grup idola JKT48 yang di mana setiap penggemar (Fans

Pemilihan Member Single ke-17 JKT48

Pemilihan Member Single ke-17 JKT48 "Siapa yang akan membuat zaman baru?" merupakan pemungutan suara untuk menentukan anggota pilihan yang berhak untuk