Algoritma Paralel - Struktur

Untuk menerapkan algoritme apa pun dengan benar, Anda harus memilih struktur data yang tepat. Ini karena operasi tertentu yang dilakukan pada struktur data mungkin memerlukan lebih banyak waktu dibandingkan dengan operasi yang sama yang dilakukan pada struktur data lain.

Example- Untuk mengakses elemen ke- i dalam satu set dengan menggunakan larik, mungkin diperlukan waktu yang konstan tetapi dengan menggunakan daftar tertaut, waktu yang diperlukan untuk melakukan operasi yang sama dapat menjadi polinomial.

Oleh karena itu, pemilihan struktur data harus dilakukan dengan mempertimbangkan arsitektur dan jenis operasi yang akan dilakukan.

Struktur data berikut biasanya digunakan dalam pemrograman paralel -

  • Daftar Tertaut
  • Arrays
  • Jaringan Hypercube

Daftar Tertaut

Daftar tertaut adalah struktur data yang memiliki nol atau lebih node yang dihubungkan oleh pointer. Node mungkin atau mungkin tidak menempati lokasi memori berturut-turut. Setiap node memiliki dua atau tiga bagian - satudata part yang menyimpan data dan dua lainnya link fieldsyang menyimpan alamat node sebelumnya atau berikutnya. Alamat node pertama disimpan di pointer eksternal yang disebuthead. Node terakhir, yang dikenal sebagaitail, umumnya tidak mengandung alamat apapun.

Ada tiga jenis daftar tertaut -

  • Daftar Tertaut Tunggal
  • Daftar Tertaut Ganda
  • Daftar Tertaut Melingkar

Daftar Tertaut Tunggal

Sebuah node dari daftar tertaut tunggal berisi data dan alamat dari node berikutnya. Penunjuk eksternal disebuthead menyimpan alamat node pertama.

Daftar Tertaut Ganda

Node dari daftar tertaut ganda berisi data dan alamat node sebelumnya dan berikutnya. Penunjuk eksternal disebuthead menyimpan alamat dari node pertama dan pointer eksternal dipanggil tail menyimpan alamat node terakhir.

Daftar Tertaut Melingkar

Daftar tertaut melingkar sangat mirip dengan daftar tertaut tunggal kecuali fakta bahwa simpul terakhir menyimpan alamat simpul pertama.

Array

Array adalah struktur data tempat kita dapat menyimpan jenis data yang serupa. Bisa satu dimensi atau multi-dimensi. Array dapat dibuat secara statis atau dinamis.

  • Di statically declared arrays, dimensi dan ukuran array diketahui pada saat kompilasi.

  • Di dynamically declared arrays, dimensi dan ukuran larik diketahui saat runtime.

Untuk pemrograman memori bersama, array dapat digunakan sebagai memori umum dan untuk pemrograman paralel data, array dapat digunakan dengan mempartisi ke dalam sub-array.

Jaringan Hypercube

Arsitektur hypercube sangat membantu untuk algoritma paralel tersebut di mana setiap tugas harus berkomunikasi dengan tugas lain. Topologi hypercube dapat dengan mudah menyematkan topologi lain seperti ring dan mesh. Ia juga dikenal sebagai n-kubus, di mananadalah jumlah dimensi. Hypercube dapat dibangun secara rekursif.