Меня попросили вычислить следующее вложенное корневое выражение, используя только рекурсию .
Я написал код ниже, который работает, но они позволили нам использовать только одну функцию и 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
?