Pediram-me para calcular a seguinte expressão raiz aninhada usando apenas recursão .
Eu escrevi o código abaixo que funciona, mas eles nos permitiram usar apenas uma função e 1 entrada n
para esse fim, e não 2 como eu usei. Alguém pode me ajudar a transformar esse código em uma função que calculará a expressão? não pode usar nenhuma biblioteca, exceto as funções de <math.h>
.
saída para 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()
(de <stdlib.h>
), e não retornaria silenciosamente 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
?