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

Respuestas a la pregunta(10)

Su respuesta a la pregunta