Utilizando Recursion para elevar una base a su exponente - C ++
Simplemente quiero escribir un código que haga uso de la recurrencia de funciones para elevar una base a su poder. Sé que la recursividad no es la forma más correcta de hacer cosas en C ++, pero solo quiero explorar un poco el concepto. El programa le pide al usuario una base y un exponente y luego la consola muestra la respuesta. Aquí está el programa que he escrito:
#include <iostream>
#include <math.h>
using namespace std;
int raisingTo(int, int);
int main()
{
int base, exponent;
cout << "Enter base value: ";
cin >> base;
cout << "Enter exponent value: ";
cin >> exponent;
int answer = raisingTo(base, exponent);
cout << "The answer is: " << answer << endl;
char response;
cin >> response;
return 0;
}
int raisingTo(int base, int exponent)
{
if (exponent > 0)
return 1;
else if (exponent = 0)
{
int answer = (int) pow((double)base, raisingTo(base, (exponent - 1)));
return answer;
}
}
¡Lo curioso es que, cuando ejecuto este programa, sigue devolviendo la respuesta como '1'! ¿Alguien puede ayudarme con esto