Shorting Array

Shorting Array

Sorting
Salah satu bagian penting dari struktur data adalah proses pengurutan data-data  itu sendiri. Data akan terkadang akan berada dalam bentuk yang tidak berpola ataupun dengan pola tertentu yang tidak kita inginkan, namun dalam penggunaanya, kita akan selalu ingin menggunakan data-data tersebut dalam bentuk yang rapi atau berpola sesuai dengan yang kita inginkan. Maka dari itu proses sorting adalah proses yang sangat penting dalam struktur data, terlebih untuk pengurutan data yang bertipe numerik ataupun karakter.



Sorting adalah proses menyusun kembali data yang sebelumnya telah disusun dengan suatu pola tertentu ataupun secara acak, sehingga menjadi tersusun secara teratur menurut aturan tertentu.


Pada umumnya ada 2 macam pengurutan, yaitu:
  • Pengurutan secara ascending (urut naik).
  • Pengurutan secara descending (urut turun).
Algoritma untuk melakukan sorting juga ada berbagai macam, antara lain:
  1. Teoretis : Computational complexity theory, Big O notation, Total order, Stability, Comparison sort.
  2. Exchange sorts : Exchange sort, Bubble sort, Cocktail sort, Comb sort, Gnome sort, Quick sort.
  3. Selection sorts  : Selection sort, Heap sort, Smooth sort.
  4. Insertion sorts   : Insertion sort, Shell sort, Tree sort, Library sort, Patience sorting.
  5. Merge sorts     : Merge sort.
  6. Non-comparison : Radix sort, Bucket sort, Counting sort, Pigeonhole sort.
  7. Others  : Topological sorting, Sorting network.
Algoritma-algoritma ini tentu saja akan mempunyai efek yang berbeda dalam setiap prosesnya, ada yang mudah digunakan, ada yang mempunyai proses yang sangat cepat, dan sebagainya.
Pemilihan algoritma untuk sorting ini tidak hanya asal saja dipilih. Pemilihian ini semestinya berdasarkan kebutuhan yang diperlukan. Tidak semua algortima yang pendek itu buruk dan tidak semua algoritma yang super cepat juga akan baik dalam semua kondisi. Misal: algoritma Quick Sort adalah algoritma sorting yang tercepat dalam proses pencariannya, namun jika data yang akan diurutkan ternyata sudah hampir terurut atau tidak terlalu banyak, maka algoritma ini malah akan memperlama proses pengurutan itu sendiri, karena akan banyak perulangan tidak perlu yang dilakukan dalam proses sorting ini.
Hal yang umum dilakukan dalam proses sorting adalah proses pertukaran antara 2 elemen atau lebih (analogi memindah air dalam gelas). Untuk melakukan proses pertukaran akan diperlukan adanya variable baru yang digunakan sebagai variable penampung.

Sebagai contoh saya akan buat satu deklarasi sebagai berikut ;

Data hosted with ♥ by Pastebin.com - Download Raw - See Original
  1. //fungsi penukar data
  2. void tukar (int a[]int I, int j) {
  3. int tampung = a[i];
  4. a[i] = a[j];
  5. a[j] = tampung;
  6. }

Buble Sort
Berikut adalah deklarasi dari Sorting jenis ini :
  • Metode sorting paling mudah, namun paling lambat dibandingkan dengan yang lain.
  • Bisa dilakukan baik dari kepala array maupun ekor array.
  • Bubble sort mengurutkan data dengan cara membandingkan elemen sekarang dengan elemen berikutnya.
  • Proses yang berlangsung, jika: Ascending: jika elemen sekarang lebih besar daripada elemen berikutnya, maka kedua elemen tersebut ditukar. Descending: jika elemen sekarang lebih kecil daripada elemen berikutnya, maka kedua elemen tersebut ditukar.
  •  Hal ini akan terlihat seperti penggeseran angka, perbandingan, kemudian jika memenuhi syarat kemudian tukar.
  •  Proses penukaran ini akan terus dilakukan hingga seluruh array telah diperiksa.
Contoh fungsi nya :
Data hosted with ♥ by Pastebin.com - Download Raw - See Original
  1. //Bubble Sort
  2. void bubble (int a[]int n) {
  3. int i,j;
  4. for (i=n;i>=1;i--) {
  5.   for (j=2;j<i;j++)
  6.   if(a[j-1]>a[j])
  7.   tukar (a,j-1,j);
  8.   }
  9. }

Exchange Sort
Berikut adalah deklarasi dari Sorting jenis ini :
  • Mirip dengan bubble sort.
  • Perbedaannya: dalam exchange sort ada elemen yang berfungsi sebagai pusat (pivot), pertukaran hanya akan dilakukan jika diperlukan saja dari pivot tersebut.
  • Sedangkan bubble sort akan membandingkan elemen pertama/terakhir dengan elemen sebelumnya/sesudahnya, kemudian elemen sebelum/sesudahnya itu akan menjadi pusat (pivot) untuk dibandingkan dengan elemen sebelumnya/sesudahnya lagi, begitu seterusnya.
Contoh fungsi nya :
Data hosted with ♥ by Pastebin.com - Download Raw - See Original
  1. //Exchange Sort
  2. void exchange (int a[]int n) {
  3. int i,j;
  4. for (i=0;i<=n-1;i++) {
  5.   for (j=(i+1);j<n;j++)
  6.   if(a[i]>a[j])
  7.   tukar (a,i,j);
  8.   }
  9. }

Selection Sort
Berikut adalah deklarasi dari Sorting jenis ini :
  • Kombinasi sorting dan searching.
  • Untuk setiap proses, akan dilakukan dengan mencari elemen dari posisi yang belum diurutkan dan kemudian memilih elemen yang memiliki nilai terkecil atau terbesar yang akan ditukarkan ke posisi yang tepat di dalam array.
  • Misalnya untuk putaran pertama, akan dicari data dengan nilai terkecil dan data ini akan ditempatkan pada indeks terkecil, pada putaran kedua akan dicari data kedua terkecil, dan akan ditempatkan di indeks kedua, negitu seterusnya hingga tidak ada data yang dicari lagi.
  • Selama proses, pembandingan dan pengubahan hanya dilakukan pada indeks pembanding saja, pertukaran data secara fisik terjadi pada akhir proses.
Contoh fungsi nya :
Data hosted with ♥ by Pastebin.com - Download Raw - See Original
  1. //Selection Sort
  2. void selection (int a[],int n) {
  3. int i,j,pos;
  4. for (i=1;i<n;i++) {
  5.    pos=i;
  6.    for (j=i+1;j<=n;j++)
  7.    if(a[j]<a[pos])
  8.    pos=j;
  9.    tukar(a,pos,i);
  10.    }
  11. }

Insertion Sort
Berikut adalah deklarasi dari Sorting jenis ini :
  • Analogi pengurutan kartu.
  • Proses dilakukan dengan membandingkan data ke-I dengan data yang sebelum-sebelumnya.
  • Misal ascending: pengurutan dimulai dari data ke-2 sampai dengan data terakhir, jika ditemukan data yang lebih kecil, maka akan dimasukkan di posisi yang seharusnya.
  • Pada penyisipan elemen, maka elemen-elemen lain akan bergeser ke belakang.
Contoh fungsi nya :
Data hosted with ♥ by Pastebin.com - Download Raw - See Original
  1. //Insertion Sort
  2. void insertion (int a[],int n) {
  3. int i,j,v;
  4. for (i=2;i<=n;i++) {
  5.     v=a[i];
  6.     j=1;
  7. while (a[j-1]>v) {
  8.     a[j]=a[j-1]
  9.     j--;
  10.     a[j=v];
  11.     }
  12. }
Quick Sort
Berikut adalah deklarasi dari Sorting jenis ini :
  • Bersifat divide&conquer.
  • Merupakan metode pencarian yang sangat cepat (saat ini tercepat).
  • Pertama-tama deret dibagi menjadi dua bagian, misal, semua elemen pada bagian b (bagian pertama) mempunyai kurang dari atau sama dengan semua elemen pada bagaian c (bagian kedua -- membagi). Kemudian kedua bagian tersebut dilakukan proses sorting dengan rekursif secara terpisah dengan prosedur yang sama(coquer). Kemudian gabungkan lagi kedua bagian terpisah tersebut.

Langkah-langkahnya :
  • Memilih sebuah elemen pembanding (pivot), misal x.
  • Semua elemen dari deret tersebut yang kurang dari x diletakkan pada bagian pertama.
  • Kemudian semua elemen dari yang lebih besar dari x diletakkan pada bagian kedua.
  • Untuk elemen yang sama dengan x bias diletakkan di mana saja bahkan bisa juga di antara kedua bagian tersebut.
Algoritma Partisi :
  • setelah mempartisi, prosedur sorting akan dilakukan secara rekursif. Hingga proses rekursif tersebut akan berhenti saat sebuah bagian hanya tinggal terdapat satu elemen saja.
  • Tidak baik digunakan jika elemen-elemen yang akan diurutkan hanya ada sedikit atau sudah hamper terurut, karena jika menggunakan metode ini justru akan melakukan perulangan yang tidak berguna dan lama.
  • Mempunyai algoritma dan program yang cukup kompleks.
Contoh fungsi nya :

Data hosted with ♥ by Pastebin.com - Download Raw - See Original
  1. //Quick Sort
  2. void quicksort (int a[],int l,int r) {
  3. int i,j,v;
  4. if(r>1) {
  5. v=a[r];i=l-1;j=r;
  6.   for(;;) {
  7.     while(a[++i]<v);
  8.     while(a[--j]>v);
  9.     if(i>=j)
  10.     break;
  11.     tukar(a,i,j)
  12.     }
  13.   tukar(a,i,r);
  14.   quicksort(a,l,i-1);
  15.   quicksort(a,i+1,r);
  16.   }
  17. }

Komentar

Postingan populer dari blog ini

KONSEP TIPE DATA, OPERATOR DAN IDENTIFIER

Pengenalan Komputer

Stack and Queue