BAB 2 LANDASAN TEORI
2.1.
Algoritma
Istilah algoritma (algorithm) berasal dari kata “algoris” dan “ritmis”, yang pertama kali diungkapkan oleh Abu Ja‟far Mohammed Ibn Musa al Khowarizmi (825 M) dalam buku Al-Jabr Wa-al Muqabla. Dalam bidang pemrograman algoritma didefenisikan sebagai suatu metode khusus yang tepat dan terdiri dari serangkaian langkah yang terstruktur dan dituliskan secara matematis yang akan dikerjakan untuk menyelesaikan suatu masalah dengan bantuan komputer. (Jogiyanto, 2005). Istilah algoritma digunakan dalam ilmu komputer untuk menggambarkan metode pemecahan masalah yang terbatas, deterministik, dan efektif yang cocok untuk implementasi sebagai program komputer. (Sedgewick. 2011). Terdapat beberapa defenisi yang diberikan untuk kata algoritma antara lain (Priyatna. 2015) : a. Algoritma adalah sekelompok aturan untuk menyelesaikan perhitungan yang dilakukan oleh tangan atau mesin. b. Algoritma adalah langkah demi langkah sebuah prosedur berhinggga yang dibutuhkan untuk menghasilkan sebuah penyelesaian. c. Algoritma adalah urutan langkah-langkah perhitungan yang mentrasformasikan dari nilai masukan menjadi keluaran. d. Algoritma adalah urutan operasi yang dilakukan terhadap data yang terorganisasi dalam struktur data. e. Algoritma adalah sebuah program abstrak yang dapat dieksekusi secara fisik oleh mesin. f. Algoritma adalah sebuah model perhitungan yang akan dilakukan oleh komputer.
Universitas Sumatera Utara
2.2.
Algoritma Pencocokan String
Algoritma pencocokan string (string matching) merupakan komponen dasar dalam pengimplementasian berbagai perangkat lunak praktis yang sudah ada. String matching digunakan untuk menemukan satu atau lebih string yang disebut dengan pattern (string yang akan dicocokkan ke dalam text) dalam string yang disebut dengan text (string yang di-input). (Charras. 1997). Algoritma yang dianggap memiliki hasil yang paling baik dalam praktiknya merupakan algoritma yang bergerak mencocokan string dari arah kanan ke kiri. Untuk mengetahui manakah algoritma yang mampu mencari string paling cepat, maka muncullah ide untuk meneliti kemampuan dari algoritma-algoritma ini. (Sagita. 2013). String adalah rangkaian karakter selama Σ alphabet yang terbatas. Misalnya, ATCTAGAGA adalah string lebih
. Masalah pencocokan string adalah
untuk menemukan semua kejadian dari string P yang disebut pola, di string T pada alphabet yang sama yang disebut teks. Mengingat string x, y, dan z kita mengatakan bahwa x adalah awalan dari xy, akhiran dari yx, dan faktor yxz. (Navarro. 2002). Exact string matching, yaitu pencocokan sebuah string secara sangat tepat dengan susunan karakter dalam string yang dicocokkan baik dalam jumlah maupun urutan karakter dalam stringnya. Pada proses pencocokan string, digunakan sebuah window yang akan bergeser di text. Window itu memiliki panjang yang sama dengan panjang pattern. Pada awal proses pencocokan string, window diletakkan pada ujung kiri text, lalu karakter-karakter pada window dibandingkan dengan karakter-karakter pada pattern, kemudian window akan digeser ke kanan di text dengan jarak tertentu, dan pergeseran tersebut baru akan berhenti bila window tersebut sampai pada ujung kanan text atau sampai pattern ditemukan cocok. (Charras. 1997). Contoh sliding windows yang sedang menggeser pattern di teks dapat dilihat di Gambar 2.1.
Universitas Sumatera Utara
Gambar 2.1 Mekanisme Sliding Windows
Algoritma pencocokan string dapat diklasifikasikan menjadi tiga bagian menurut pencariannya, (Charras. 1997) : a. Kategori pertama, arah yang paling alami dalam pencocokan string yaitu dari kiri ke kanan. Algoritma kategori ini melakukan pencocokan string dimulai dari karakter paling kiri pattern seperti yang ditunjukkan pada Gambar 2.2. Beberapa algoritma yang termasuk dalam kategori ini adalah algoritma brute force, algoritma Karb-Rabin, dan algoritma Knuth-Morris-Pratt.
Gambar 2.2 Pencocokan dari Karakter Paling kiri ke Paling Kanan Pattern
b. Kategori kedua, algoritma yang melakukan pencocokan dari kanan ke kiri karakter pada pattern seperti yang dapat dilihat pada Gambar 2.3. Algoritma yang termasuk dalam kategori ini umumnya dikatakan sebagai algoritma yang menghasilkan hasil terbaik pada praktekmya, yaitu algoritma Boyer-Moore.
Gambar 2.3 Pencocokan dari Karakter Paling Kanan ke Paling Kiri Pattern
Universitas Sumatera Utara
c. Kategori ketiga yaitu pencocokan dari dua arah yang telah ditentukan oleh tiap algoritma tertentu. Salah satunya seperti yang diterapkan oleh Galil-Seiferas dan Crochemore-Perrin dalam algoritma Two Way, mereka membagi pattern y menjadi dua bagian yaitu y = y1y2. Seperti yang dapat kita lihat pada Gambar 2.4, pertama kali, pencarian terjadi pada y2 yang dilakukan dari karakter paling kiri ke kanan, apabila selama pencarian pertama tidak terjadi ketidakcocokan atau pattern y2 cocok dengan text selanjutnya pada pencarian kedua algoritma akan memeriksa pada y1 yang
dilakukan dari kanan ke kiri seperti yang ditunjukkan pada Gambar 2.5.
Gambar 2.4 Pencocokan Pattern y2 Dimulai dari Karakter Paling Kiri
Gambar 2.5 Pencocokan Pattern y1 Dimulai dari Karakter Paling Kanan
2.3.
Algoritma Galil-Seiferas
Algoritma Galil-Seiferas merupakan algoritma yang menggunakan konstanta k oleh Galil dan Seiferas dinyatakan bernilai 4. Fungsi reach jangkauan untuk 0 ≤ i <m sebagai berikut: (i) = i + max {i ' ≤ m - i: x [0 .. i '] = x [i +1 .. i' + i +1]}. Sebuah awalan x [0 .. p] dengan x adalah periode awalan jika dasar dan mencapai (p)≥ kp. Tahap preprocessing pada algoritma ini berguna untuk mendapatkan dekomposisi uv dari P yang mana v memiliki paling banyak satu periode awalan dan | u | = Ο (per (v)), proses dekomposisi dinamakan perfect factorization. Pada tahap
Universitas Sumatera Utara
searching dilakukan pencarian pada teks T untuk menemukan setiap v dan ketika ditemukan akan dilanjutkan dengan pencarian terhadap u tepat disebelahnya pada T. (Charras. 1997). Implementasi
dalam
(fungsi newP1, newP2 dan mengurai) adalah
fase untuk
preprocessing
menemukan
uv faktorisasi
sempurna x dimana u = x[0....s-1] dan v = x[s....m-1]. Fungsi newP1 menemukan periode awalan terpendek x[s...m-1]. Fungsi newP2 menemukan periode awalan terpendek kedua dari x[s...m-1] dan fungsi parse terhadap s. Sebelum memanggil fungsi pencarian kita memiliki: a. x[s...m-1] memiliki paling banyak satu periode awalan; b. Jika x[s...m-1] tidak memiliki masa awalan, maka panjangnya adalah p1; c. x[s...s+p1+q1-1] memiliki periode terpendek panjang p1; d. x[s...s+p1+q1] tidak memiliki periode panjang p1;
Gambar 2.6 Faktorisasi Sempurna x
Pola x adalah dari bentuk x[0...s-1] x[s...m-1] dimana x[s...m-1] adalah dari bentuk z
z’ z” dengan z dasar, |z|=p1.z’ awalan z, z’ tidak awalan z dan | z z '| =
p1+q1. Pada Gambar 2.4 terlihat bahwa ketika mencari x[s...m-1] di y, jika x[s...s+p1+q1-1] telah dicocokkan pergeseran panjang p1 dapat dilakukan dan perbandingan
yang
dilanjutkan
dengan
x[s+q1].
Sebaliknya
jika
terjadi
ketidakcocokan dengan x[s+q] dengan q ≠ p1 + q1 maka pergeseran panjang q/k1 dapat dilakukan dan perbandingan yang dilanjutkan dengan x[0]. Hal ini memberikan jumlah linier keseluruhan perbandingan karakter teks. Tahap preprocessing dari algoritma Galil-Seiferas di Ο(m) waktu dan kompleksitas ruang konstan. Fase pencarian di Ο(n) kompleksitas waktu. Paling banyak 5n perbandingan karakter teks dapat dilakukan selama fase ini. (Charras. 1997).
Universitas Sumatera Utara
Program dalam Bahasa C char *x, *y; int k, m, n, p, p1, p2, q, q1, q2, s; void search() { while (p <= n - m) { while (p + s + q < n && x[s + q] == y[p + s + q]) ++q; if (q == m - s && memcmp(x, y + p, s + 1) == 0) OUTPUT(p); if (q == p1 + q1) { p += p1; q -= p1; } else { p += (q/k + 1); q = 0; } } } void parse() { while (1) { while (x[s + q1] == x[s + p1 + q1]) ++q1; while (p1 + q1 >= k*p1) { s += p1; q1 -= p1; } p1 += (q1/k + 1); q1 = 0; if (p1 >= p2) break; } newP1(); } void newP2() { while (x[s + q2] == x[s + p2 + q2] && p2 + q2 < k*p2) ++q2; if (p2 + q2 == k*p2) parse(); else if (s + p2 + q2 == m) search(); else { if (q2 == p1 + q1) { p2 += p1; q2 -= p1; } else { p2 += (q2/k + 1); q2 = 0; } newP2(); } }
Universitas Sumatera Utara
void newP1() { while (x[s + q1] == x[s + p1 + q1]) ++q1; if (p1 + q1 >= k*p1) { p2 = q1; q2 = 0; newP2(); } else { if (s + p1 + q1 == m) search(); else { p1 += (q1/k + 1); q1 = 0; newP1(); } } } void GS(char *argX, int argM, char *argY, int argN) { x = argX; m = argM; y = argY; n = argN; k = 4; p = q = s = q1 = p2 = q2 = 0; p1 = 1; newP1(); }
Contoh : Fase Pre-Processing P= 0, q = 0, s = 0, p 1 = 7, q 1 = 1 Fase Searching Algoritma Galil - Seiferas melakukan 24 perbandingan karakter
Universitas Sumatera Utara
Universitas Sumatera Utara
Gambar 2.7 Fase Pencarian dengan Algoritma Galil-Seiferas.
2.4.
Algoritma Not So Naϊve
Algoritma Not So Naϊve bekerja dimana selama fase pencarian dalam perbandingan karakter yang dibuat diatur dalam susunan sebagai berikut: 1, 2,...., m-2, m-1, 0. Untuk setiap upaya dimana jendela diposisikan pada faktor teks: y [j .. j + m -1]: jika x [0] = x [1] dan x [1] dari jika x [0]
y [j+1]
x [1] dan x [1] = y [j+1]
pola digeser oleh 2 posisi pada akhir upaya dan dengan 1 sebaliknya. Dengan demikian tahap preprocessing dapat dilakukan dalam ruang dan waktu yang konstan. Tahap pencarian algoritma Not So Naïve memiliki kasus kuadrat terburuk tapi itu sedikit (dengan koefisien) sub-linear dalam kasus rata-rata. (Charras. 1997).
Program Bahasa C void NSN(char *x, int m, char *y, int n) { int j, k, ell; /* Preprocessing */ if (x[0] == x[1]) { k = 2; ell = 1; } else { k = 1; ell = 2; } /* Searching */ j = 0; while (j <= n - m) if (x[1] != y[j + 1]) j += k; else { if (memcmp(x + 2, y + j + 2, m - 2) == 0 && x[0] == y[j]) OUTPUT(j); j += ell; } }
Universitas Sumatera Utara
Contoh : Fase Pre-processing k=1 and =2 Fase Searching Algoritma Not So Naϊve melakukan 24 perbandingan karakter
Universitas Sumatera Utara
Gambar 2.8 Fase Pencarian dengan Algoritma Not So Naϊve
Universitas Sumatera Utara
2.5.
Kompleksitas Algoritma
Algoritma merupakan salah satu cabang ilmu komputer yang membahas prosedur penyelesaian suatu permasalahan. Dalam beberapa konteks, algoritma merupakan spesifikasi urutan langkah untuk melakukan pekerjaan tertentu. Algoritma adalah prosedur komputasi yang terdefenisi dengan baik yang menggunakan beberapa nilai sebagai masukan dan menghasilkan beberapa nilai sebagai masukan dan menghasilkan beberapa nilai yang disebut keluaran. (Munir. 2007). Adanya algoritma yang baik maka komputer bisa menyelesaikan perhitungan dengan cepat dan benar. Sebaliknya jika algoritma kurang baik maka penyelesaian lambat dan bahkan tidak didapat solusi yang diharapkan. Baik buruknya sebuah algoritma dapat dibuktikan dari kompleksitas waktu yang digunakan. Kompleksitas dari suatu algoritma merupakan seberapa banyak komputasi yang dibutuhkan algoritma tersebut untuk menyelesaikan masalah. Secara informal, algoritma yang dapat menyelesaikan suatu permasalahan dalam waktu yang singkat memiliki kompleksitas yang rendah, sementara algoritma yang membutuhkan waktu lama untuk menyelesaikan masalahnya mempunyai kompleksitas yang tinggi. (Azizah. 2013). Dua hal penting untuk mengukur efektivitas suatu algoritma yaitu kompleksitas ruang (keadaan) dan kompleksitas waktu. Kompleksitas ruang berkaitan dengan sistem memori yang dibutuhkan dalam eksekusi program. Kompleksitas waktu dari algoritma berisi ekspresi bilangan dan jumlah langkah yang dibutuhkan sebagai fungsi dari ukuran permasalahan. Analisa asimtotik menghasilkan notasi Ο (Big O) dan dua notasi untuk komputer sain yaitu
ϴ (Big Theta) dan Ω (Big Omega).
(Purwanto. 2008). Kinerja algoritma dibuktikan dengan menjumlahkan bilangan bulat dari masing-masing operasi ketika algoritma di jalankan. Kinerja sebuah algoritma dievaluasi sebagai fungsi ukuran masukan n dan konstanta modulo pengali yang digunakan. Pada penelitian ini kompleksitas yang digunakan adalah Big(ϴ).
Universitas Sumatera Utara
8.4.1. Big-O (O) Secara informal, O(g(n)) adalah himpunan semua fungsi yang lebih kecil atau dengan urutan yang sama dengan g(n) (hingga beberapa konstanta, sampai n ke tak terhingga). Sebuah fungsi t(n) dikatakan bagian dari Ο((g(n)) yang dilambangkan dengan t(n) Є Ο(g(n)), jika t(n) batas atasnya adalah beberapa konstanta g(n) untuk semua n besar, jika terdapat konstanta c positif dan beberapa bilangan bulat tidak negatif n0 seperti t(n) ≤ cg(n) untuk semua n≥n0 . ( Levitin. 2011).
8.4.2. Big Omega (Ω) Ω(g(n)) merupakan himpunan semua fungsi dengan tingkat pertumbuhan lebih besar atau sama dengan g(n) (hingga beberapa konstanta, sampai n ke tak terhingga). Sebuah fungsi t(n) dikatakan bagian dari Ω(g(n)), dilambangkan dengan t(n) Є Ω(g(n)), jika t(n) batas bawahnya adalah beberapa konstanta positif dari g(n) untuk semua n besar. Terdapat konstanta c positif dan beberapa bilangan bulat tidak negatif n0 seperti t(n) ≥ cg(n), (untuk setiap n ≥ n0). (Levitin. 2011).
8.4.3. Big Theta (ϴ) ϴ(g(n)) adalah himpunan semua fungsi yang memiliki tingkat pertumbuhan yang sama dengan g(n) (hingga beberapa konstanta, sampai n ke tak terhingga). Sebuah fungsi t(n) dikatakan bagian dari ϴ(g(n)), dilambangkan dengan t(n) Є ϴ(g(n)), jika t(n) batas atas dan bawahnya adalah beberapa konstanta positif g(n) untuk semua n yang besar, yaitu jika ada beberapa konstanta positif c1 dan c2 serta beberapa bilangan bulat non-negatif n0 seperti c2g(n) ≤ t(n) ≤ c1g(n) untuk semua n ≥ n0. (Levitin. 2011).
2.6.
Kamus
Menurut Kamus Besar Bahasa Indonesia (KBBI), pengertian kamus adalah buku acuan yang memuat kata dan ungkapan yang biasanya disusun menurut abjad berikut keterangan maknanya, pemakaiannya dan terjemahannya. Kamus juga dapat digunakan sebagai buku rujukan yang menerangkan makna kata – kata yang berfungsi untuk membantu seseorang mengenal perkataan baru. Selain menerangkan makna kata, kamus juga mungkin mempunyai pedoman sebutan, asal-usul (etimologi) suatu
Universitas Sumatera Utara
perkataan dan juga contoh penggunaan bagi kata tersebut. Kamus disusun sesuai dengan abjad dari A-Z dengan tujuan memudahkan pengguna kamus dalam mencari istilah yang diinginkannya dengan cepat dan mudah. Secara fisik, kamus terbagi menjadi dua jenis yaitu kamus yang berbentuk buku dan kamus elektronik (digital). Kamus berbentuk buku terdiri dari puluhan bahkan ratusan lembar halaman kata. Berbeda dengan kamus buku yang cenderung besar dan tebal, kamus elektronik atau kamus digital merupakan sebuah fasilitas yang membantu pengguna mencari kata dengan cara mengetikkan kata yang diinginkan pada kolom pencarian. Penggunaan kamus elektronik atau kamus digital ini lebih efisien dalam hal waktu dibandingkan dengan kamus buku. (Tania. 2015). Kamus digital lebih mengutamakan pada fasilitas pengolah kata elektronis, yaitu sebuah fasilitas yang memungkinkan aplikasi pengolah kata memeriksa ejaan dari dokumen yang diketik. Hal ini dapat meminimumkan kemungkina salah eja atau salah ketik. Pengguna kamus elektronis atau kamus digital dalam aplikasi pemrosesan teks merupakan hal yang tidak dapat dihindarkan. Kamus merupakan basis pemeriksaan, basis pengetahuan, bahkan sebagai basis penyelidikan (Pasaribu. 2013).
2.7.
Hukum
Hukum merupakan sistem yang terpenting dalam pelaksaan atas rangkaian kekuasaan kelembagaan. Menurut Prof. E. Utrecht, defenisi hukum adalah himpunan petunjuk hidup yang mengatur tata tertib dalam suatu masyarakat dan seharusnya ditaati oleh anggota masyarakat yang besangkutan, oleh karena pelanggaran terhadap petunjuk hidup itu dapat menimbulkan tindakan dari pemerintah masyarakat itu. (Djindang. 1989). Tujuan Hukum dalam UUD 1945 yaitu melindungi segenap bangsa Indonesia dan seluruh tumpah darah Indonesia dan untuk memajukan kesejahteraan umum, mencerdaskan kehidupan bangsa, serta ikut melaksanakan ketertiban dunia yang berdasarkan perdamaian abadi dan keadilan sosial. Tujuan hukum itu sebenarnya menghendaki adanya keseimbangan kepentingan, ketertiban, keadilan, ketentraman, kebahagiaan,damani sejahtera setiap manusia. Dengan demikian jelas bahwa yang dikehendaki oleh hukum adalah agar kepentingan setiap orang baik secara individual maupun kelompok tidak diganggu oleh orang atau kelompok lain yang selalu
Universitas Sumatera Utara
menonjolkan kepentingan pribadinya atau kepentingan kelompoknya. Inti tujuan hukum adalah agar tercipta kebenaran dan keadilan. Adapun fungsi hukum di Indonesia antara lain adalah sebagai pedoman atau arahan pada warga masyarakat berperilaku, sebagai pengendali sosial (social control), sebagai penyelesaian sengketa (dispute settlemen), dan sebagai rekayasa sosial (social engineering). (Yunasril. 2009).
Universitas Sumatera Utara