Tambahkan seluruh angka sampai angka yang diberikan
Tulis sebuah fungsi sumTo(n)
yang mengkalkulasikan penambahan dari angka 1 + 2 + ... + n
.
Contoh:
sumTo(1) = 1
sumTo(2) = 2 + 1 = 3
sumTo(3) = 3 + 2 + 1 = 6
sumTo(4) = 4 + 3 + 2 + 1 = 10
...
sumTo(100) = 100 + 99 + ... + 2 + 1 = 5050
Buatlah jawaban dengan 3 varian:
- Gunakan perulangan
- Gunakan rekursi, karena
sumTo(n) = n + sumTo(n-1)
untukn > 1
. - Gunakan rumus arithmetic progression.
Contoh dari hasil:
function sumTo(n) { /*... kodemu ... */ }
alert( sumTo(100) ); // 5050
Catatan. Varian solusi mana yang lebih cepat? yang lebih lambat? kenapa?
Catatan+. Bisakah kita gunakan rekursi untuk menghitung sumTo(100000)
?
Solusi menggunakan perulangan:
function sumTo(n) {
let sum = 0;
for (let i = 1; i <= n; i++) {
sum += i;
}
return sum;
}
alert( sumTo(100) );
Solusi menggunakan rekursi:
function sumTo(n) {
if (n == 1) return 1;
return n + sumTo(n - 1);
}
alert( sumTo(100) );
Solusi menggunakan rumus: sumTo(n) = n*(n+1)/2
:
function sumTo(n) {
return n * (n + 1) / 2;
}
alert( sumTo(100) );
Catatan. Biasanya, rumus adalah solusi tercepat. Itu hanya menggunakan 3 operasi untuk angka n
apapun. Matematika mambantu!
varian perulangan adalah yang kedua dalam hal waktu. Di varian rekusif dan perulangan kita menambahkan angka yang sama. Tapi rekursi melibatkan pemanggilan bercabang dan manajemen tumpukan eksekusi. Itu juga memakan sumberdaya, jadi itu lebih lambat.
Catatan+. Beberapa mesin mendukung optimasi ???tail call???: jika sebuah pemanggilan rekursi adalah yang paling terakhir didalam fungsi (seperti dalam sumTo
diatas), maka fungsi terluar tidak butuh untuk melanjutkan eksekusi, jadi mesinnya tidak akan mengingat konteks dari eksekusi. Itu akan menghilangkan beban didalam memori, jadi menghitung sumTo(100000)
menjadi mungkin. Tapi jika mesin Javascript tidak mendukung optimasi tail call (kebanyakan tidak), disana akan terdapat error: ???maximum stack size exceeded???, karena disana biasanya terdapat batasan dalam total ukuran stack/penumpukan.