Optimasi Kode di Java
Pavlos Kosmetatos
Lead Engineer @Wealthyhood
Memahami kompleksitas ruang penting untuk membangun aplikasi yang:
OutOfMemoryErrorNotasinya sama dengan kompleksitas waktu.
Beberapa kelas kompleksitas umum:
O(1): Konstan - tidak bergantung ukuranO(n): Linear - tumbuh seiring ukuran inputO(n²): Kuadratik - tumbuh kuadratik terhadap ukuran inputpublic int findMax(int[] array) {
int max = Integer.MIN_VALUE;
for (int value : array) {
if (value > max) {
max = value;
}
}
return max;
}
Baik array berisi 10 atau 10 juta elemen, kita hanya memakai memori untuk satu variabel max
Kompleksitas ruangnya O(1) atau konstan
public int[] doubleValues(int[] array) {
int[] result = new int[array.length];
for (int i = 0; i < array.length; i++) {
result[i] = array[i] * 2;
}
return result;
}
n elemen, kita butuh ruang untuk n elemen tambahanO(n) karena memori ekstra tumbuh linear dengan ukuran inputpublic int[][] multiplicationTable(int n) {
int[][] table = new int[n][n];
for (int i = 0; i < n; i++) {
for (int j = 0; j < n; j++) {
table[i][j] = (i + 1) * (j + 1);
}
}
return table;
}
n adalah 10, kita butuh 100 sel; jika n adalah 100, kita butuh 10.000 selO(n²)Memori itu terbatas!
Contoh sebelumnya untuk ukuran input 10.000 elemen:
findMax, O(1) -> hanya beberapa byte ekstradoubleValues, O(n) -> sekitar 40KB memori ekstramultiplicationTable, O(n²) -> sekitar 400MB memori ekstra
Jangan lupa:

Optimasi Kode di Java