Sebutkan Hal yang perlu diperhatikan ketika membuat fungsi rekursi, saat melakukan pengkodean?
Hal yang harus diperhatikan ketika membuat fungsi rekursif adalah bahwa fungsi tersebut harus memiliki “base case” (kondisi basis), atau disebut juga sebagai“stopping rule” (aturan untuk berhenti), yang membuat fungsi rekursif tersebut memiliki jumlah rekurens (pemanggilan terhadap dirinya sendiri) yang terbatas/berhingga.
Jika base case tidak dapat dicapai oleh sebuah fungsi rekursif, maka fungsi tersebut tidak akan berhenti, yang dapat menyebabkan stack overflow atau penggunaan memori yang berlebihan.
Pembahasan
Secara sederhana, kita dapat mengartikan fungsi rekursif sebagai fungsi yang memanggil dirinya sendiri. Sampai berapa kali dipanggil, tentu harus didefinisikan pada sebuah kondisi basis (base case) yang jelas.
Dua elemen utama dari fungsi rekursif adalah:
base case, atau stopping rule, yang membuat fungsi berhenti dan mengembalikan nilai tertentu.
recursive step, atau langkah rekursif, di mana fungsi tersebut memanggil dirinya sendiri dengan parameter fungsi yang berubah dalam setiap kali pemanggilan dan secara bertahap mengarah ke base case.
Salah satu contoh yang dapat diambil adalah fungsi faktorial. Dalam notasi matematis, untuk n bilangan bulat tak-negatif, n faktorial yang disimbolkan dengan n! didefinisikan sebagai relasi rekurens:
(Definisi di atas sudah mencakup kasus khusus untuk 0!.)
Karena kita memiliki definisi relasi rekurens tersebut, maka implementasi fungsi faktorial(n) dalam pemrograman merupakan translasi langsung dari notasi fungsional n! tersebut.
Dari definisi tersebut, base case atau stopping rule yang berlaku adalah ketika n = 0, dan recursive step memiliki bagian yang mengarahkan n menuju base case, yaitu (n – 1).
Dengan pseudocode, algoritma fungsi rekursif faktorial(n) dapat dirancang sebagai berikut.
function faktorial(n):
if n = 0 then
return 1
end if
return n * factorial(n – 1)
Dapat kita amati bahwa fungsi faktorial(n) berhenti memanggil dirinya sendiri ketika parameternya mencapai nilai 0, yang merupakan nilai pada base case/ stopping rule.
Diketahui fungsi permintaan Qd = 0, 1P - 250. Pada… Diketahui fungsi permintaan Qd = 0, 1P - 250. Pada saat harga Rp2.000,00, barang yang akan dijual 100 unit. Ketika harga Rp3.000,00, jumlah barang yang…
Pemerintah menyediakan fasilitas untuk masyarakat… Pemerintah menyediakan fasilitas untuk masyarakat dari hasil pemungutan pajak pernyataan tersebut merupakan salah satu fungsi APBN yaitu fungsi.... a. stabilitasi b. koordinasi c. distribusi d.…
Fungsi f : r→r didefinisikan sebagai: f(x) =… Fungsi f : r→r didefinisikan sebagai: f(x) = (2x−1)/(3x+4), x ≠ (−4)/3. Invers dari fungsi adalah f^(−1)(x) = … (a) (4x+1)/(3x+2), x ≠ (−2)/3 (b)…
Fungsi yang dihasilkan dari (f+g)(x) jika diketahui… Fungsi yang dihasilkan dari (f+g)(x) jika diketahui fungsi f(x)=x+3 dan g(x)=x^(2)-9 adalah a. x^(2)+x-6 b. -x^(2)+x-6 c. x^(2)+x-12 d. -x^(2)+x-12 e. x^(2)+2x-6 Jawaban yang benar…
Di antara himpunan pasangan berurutan berikut,… Di antara himpunan pasangan berurutan berikut, manakah yang mewakili sebuah fungsi dengan daerah asal {2,3,5,7} dan daerah kawan (4,6,8,10)? a. {(2,6),(3,4),(7,10)} b. {(2,4),(3,6),(5,8),(7,10)} c. [(2,8),(3,4),(5,6),(7,4)}…
Perkembangan kota-kota besar di Indonesia sering… Perkembangan kota-kota besar di Indonesia sering kali menyebabkan alih fungsi lahan yang berada di pinggiran kota. Hal ini disebabkan…. a. ketersediaan lahan kota sudah tidak…
Tuliskan fungsi Karet gelang/ tali rafia saat membuat batik. Tuliskan fungsi Karet gelang/ tali rafia saat membuat batik. Jawaban atas pertanyaan tersebut adalah untuk pengikat pada pembuatan batik. Berikut ini penjelasannya: Batik merupakan hasil…
Diketahui f(x)=3x+4 dan g(x)=2x−1 untuk x∈R.… Diketahui f(x)=3x+4 dan g(x)=2x−1 untuk x∈R. Tentukan fungsi-fungsi berikut! (f⋅g)(x) Jawaban yang benar adalah (f · g)(x)= 6x² + 5x - 4. Sifat : (a…
Program yang memberikan jaminan kepada para peserta… Program yang memberikan jaminan kepada para peserta untuk mengatasi berbagai resiko kehilangan pendapatan yang disebabkan oleh usia pension ataupun kematian disebut fungsi …. a. fungsi…