Мене попросили обчислити наступне вкладене вираз кореня, використовуючи лише рекурсію .
Я написав код, який працює нижче, але вони дозволили нам використовувати лише одну функцію та 1 вхід n
для цієї мети, а не 2, як я використовував. Чи може хтось допомогти мені перетворити цей код на одну функцію, яка обчислить вираз? не можу використовувати будь-яку бібліотеку, крім функцій від <math.h>
.
вихід для 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()
(від <stdlib.h>
), а не мовчки повернувся 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
?