Anda di halaman 1dari 23

Kompleksitas Algoritma

Pendahuluan
• Sebuah algoritma tidak saja harus benar, tetapi juga harus mangkus
(efisien).
• Algoritma yang mangkus ialah algoritma yang meminimumkan kebutuhan
waktu dan ruang.
• Kemangkusan algoritma diukur dari berapa jumlah waktu dan ruang (space)
memori yang dibutuhkan untuk menjalankannya Analisis Algoritma
• Kebutuhan waktu dan ruang suatu algoritma bergantung pada ukuran
masukan (n), yang menyatakan jumlah data yang diproses.
• Kemangkusan algoritma dapat digunakan untuk menilai algoritma yang
terbaik.
Sebuah Algoritma harus Mangkus

10 -4 x2 n

5 10 -6 x2 n
Waktu komputasi (dalam detik) 10 1 hari

10 4
1 jam
10 3 -4 3
10 x n

10 2
1 menit
10 -6 x n 3
10
1 detik
1
5 10 15 20 25 30 35 40
-1
10 Ukuran masukan
Analisa Algoritma
• Tujuan
• Mengukur efisiensi sebuah algoritma.
• Membanding-bandingkan dua/lebih algoritma untuk masalah yang sama.
• Efisiensi diukur dari diukur dari: waktu (time) dan memori (space).
• Dua beasaran yang digunakan: kompleksitas algoritma
• Kompleksitas waktu –T(n)
• Kompleksitas ruang – S(n)
• Independen dari spesifikasi komputer dan compiler
Ukuran Input (input’s size)
• Hampir seluruh algoritma memiliki waktu eksekusi lebih lama jika
mendapat input yang berukuran besar
• Ukuran masukan (n): jumlah data yang diproses oleh sebuah
algoritma.
• Contoh:
• Algoritma pengurutan 1000 elemen larik, maka n = 1000.
• Algoritma TSP pada sebuah graf lengkap dengan 100 simpul, maka n = 100.
• Algoritma perkalian 2 buah matriks berukuran 50 x 50, maka n = 50.
• Dalam praktek perhitungan kompleksitas, ukuran masukan dinyatakan
sebagai variabel n saja.
Kompleksitas Algoritma
• Kompleksitas waktu, T(n),
• Diukur dari jumlah tahapan komputasi yang dibutuhkan untuk menjalankan algoritma sebagai fungsi dari ukuran
masukan (n).
• Dihitung dari jumlah operasi dasar yang dilakukan di dalam algoritma sebagai fungsi ukuran masukan (n). Asumsi:
setiap operasi dasar membutuhkan waktu konstan.
• Operasi dasar (Basic operation )
• The most important operation of the algorithm
• The most time-consuming operation in the algorithm’s innermost loop
• Contoh:
• Penjumlahan, pengurangan, perkalian
• Perbandingan
• Pengkasesan memori (mis: akses elemen array)
• Pembacaan, Penulisan, dll
• Dalam praktek, hanya dihitung jumlah sebuah operasi dasar yang khas (tipikal) 5 dari suatu algoritma.
Contoh operasi khas di dalam algoritma
• Algoritma pencarian di dalam larik
• Operasi khas: perbandingan elemen larik
• Algoritma pengurutan
• Operasi khas: perbandingan elemen, pertukaran elemen
• Algoritma penjumlahan 2 buah matriks
• Operasi khas: penjumlahan
• Algoritma perkalian 2 buah matriks 
• Operasi khas: perkalian dan penjumlahan
Contoh 1 : Algoritma untuk menghitung rata-
rata angka di dalam array
sum=0
for i=1 to n do
sum = sum+a[i]
endfor
rata_rata = sum/n

Pembongkaran
sum=0; 1
i=0; 1
i<n n
i++
Sum = sum+a[i] n
Rata-rata 1

persamaan
3+2n

Dibuktikan  notasi asimtotik


Contoh 2 : Algoritma untuk mencari elemen terbesar di
dalam sebuah array yang berukuran n eleman
Kompleksitas Waktu
• Tmax(n) : kompleksitas waktu untuk kasus terburuk
• (worst case) kebutuhan waktu maksimum.
• Tmin(n) : kompleksitas waktu untuk kasus terbaik
• (best case), kebutuhan waktu minimum.
• Tavg(n): kompleksitas waktu untuk kasus rata-rata
• (average case) kebutuhan waktu secara rata-rata
Pengelompokan Kompleksitas Algoritma
Kelompok Algoritma Nama
Konstant
logaritmik
lanjar
kuadratik
kubik
faktorial
Kompleksitas O(1) : Konstant
• Kompleksitas O(1) berarti waktu pelaksanaan algoritma adalah tetap,
tidak bergantung pada ukuran masukan.
Kompleksitas O(log n) : logaritmik
• O(log n) Kompleksitas waktu logaritmik berarti laju pertumbuhan
waktunya berjalan lebih lambat daripada pertumbuhan n. Algoritma
yang termasuk kelompok ini adalah algoritma yang memecahkan
persoalan besar dengan mentransformasikannya menjadi beberapa
persoalan yang lebih kecil yang berukuran sama (misalnya algoritma
pencarian biner). Di sini basis algoritma tidak terlalu penting sebab
bila n dinaikkan dua kali semula, misalnya, log n meningkat sebesar
sejumlah tetapan.
Kompleksitas O(n) : lanjar
• Algoritma yang waktu pelaksanaannya lanjar (linear) umumnya
terdapat pada kasus yang setiap elemen masukannya dikenai proses
yang sama, misalnya algoritma pencarian_beruntun. Bila n dijadikan
dua kali semula, maka waktu pelaksanaan algoritma juga dua kali
semula.
Kompleksitas : O(n log n)
• Bila n = 1000, maka n log n mungkin 20.000. Bila n dijadikan dua kali
semual, maka n log n menjadi dua kali semula (tetapi tidak terlalu
banyak).
• Waktu pelaksanaan yang n log n terdapat pada algoritma yang
memecahkan persoalan menjadi beberapa persoalan yang lebih kecil,
menyelesaikan tiap persoalan secara independen, dan menggabung
solusi masing-masing persoalan. Algoritma yang diselesaikan dengan
teknik bagi dan gabung mempunyai kompleksitas asimptotik jenis ini.
Kompleksitas O(n2) : Kuadratik
• Algoritma yang waktu pelaksanaannya kuadratik hanya praktis digunakan untuk
persoalan yang berukuran kecil. Umumnya algoritma yang termasuk kelompok ini
memproses setiap masukan dalam dua buah kalang bersarang, misalnya pada
algoritma urut_maks. Bila n = 1000, maka waktu pelaksanaan algoritma adalah
1.000.000. Bila n dinaikkan menjadi dua kali semula, maka waktu pelaksanaan
algoritma meningkat menjadi empat kali semula.

• For(int i=0; i<n; i++) i=0 1 i<n n 2n+3n2+1


•{
• For(int j=0; j<n; j++) j=0  n j<n = nxn j++ = nxn sum = nxn
• Sum = sum[i][j];
•}
Kompleksitas O (n3) : Kubik
• Seperti halnya algoritma kuadratik, algoritma kubik memproses setiap
masukan dalam tiga buah kalang bersarang, misalnya algoritma
perkalian matriks. Bila n = 100, maka waktu pelaksanaan algoritma
adalah 1.000.000. Bila n dinaikkan menjadi dua kali semula, waktu
pelaksanan algoritma meningkat menjadi delapan kali semula.
Kompleksitas O(n!) : faktorial
• Seperti halnya pada algoritma eksponensial, algoritma jenis ini
memproses setiap masukan dan menghubungkannya dengan n - 1
masukan lainnya, misalnya algoritma Persoalan Pedagang Keliling
(Travelling Salesperson Problem). Bila n = 5, maka waktu pelaksanaan
algoritma adalah 120.
Perbandingan
log n n n log n n2 n3 2n n!
0 1 0 1 1 2 1
1 2 2 4 8 4 2
2 4 8 16 64 16 24
3 9 24 64 512 256 362880
4 16 64 256 4096 65536 20922789888000
32 160 1024 32768 4294967296 (terlalu besar )
5
• Notasi “O” disebut notasi “O-Besar” (Big-O) yang merupakan notasi
kompleksitas waktu asimptotik.
DEFINISI. T(n) = O(f(n)) (dibaca “T(n) adalah O(f(n)” yang
artinya T(n) berorde paling besar f(n) ) bila terdapat konstanta
C dan n0 sedemikian sehingga

untuk

T(n) = 4n+3n+n2 = O(n2) buktikan


T(n) = 4n+3n+n2 <=4n2+3n2+n2
T(n) = 7n+n2<=8n2
• Notasi Big Oh berguna untuk membandingkan beberapa algoritma
dengan menggunakan masalah yang sama (menentukan algoritma
yang terbaik). Sebagai contoh perbandingan pertumbuhan T(n)
terhadap n2
n T(n) = n2+3n+2 N2
10 132 100
100 10.302 10.000
1.000 1.003.002 1.000.000
10.000 100.030.002 100.000.000
Latihan
•  Buktikan
Tugas
•  Buktikan bahwa :
• adalah

Anda mungkin juga menyukai