Saya diminta untuk menghitung ekspresi root bersarang berikut ini hanya menggunakan rekursi .
Saya menulis kode di bawah ini yang berfungsi, tetapi mereka memungkinkan kami untuk menggunakan hanya satu fungsi dan 1 input n
untuk tujuan dan bukan 2 seperti yang saya gunakan. Dapatkah seseorang membantu saya mengubah kode ini menjadi satu fungsi yang akan menghitung ekspresi? tidak dapat menggunakan perpustakaan apa pun kecuali fungsi dari <math.h>
.
output untuk n = 10: 1.757932
double rec_sqrt_series(int n, int m) {
if (n <= 0)
return 0;
if (m > n)
return 0;
return sqrt(m + rec_sqrt_series(n, m + 1));
}
double helper(int n) {
return rec_sqrt_series(n, 1);
}
abort()
(dari <stdlib.h>
), tidak diam-diam mengembalikan 0.
double nested_root(unsigned n) { double x = 0.0; if (n > 0) { x = nested_root(0); for (unsigned i = n; i > 0; i--) { x = sqrt(i + x); } } return x; }
helper
?