Hola, no suelo plantear problemas pero me encontré con un tema curioso.
Definí esta función
int espot(float n){
float i = 2;
while(i < n){
return 1;
i++;
}
return 0;
}
La idea es verificar si dado un entero positivo n exiten a y b enteros tales que a^b = n con b>1
Y devuelve 0 si no existen. Mi planteo fue ver si tiene raiz i-ésima entera
A mi parecer la función debería funcionar pero me devuelve 0 cuando ingreso 125
Y no es correcta la salida porque 125 = 5^3
Para cualquier otro número que he probado regresa el resultado correcto
Cuando imprimo lo que devuelven pow(n, 1/i) y floor( pow(n, 1/i) ) a lo largo del bucle
Me da que cuando n es 125 e i es 3
pow(n, 1/i) = 5.000000
floor( pow(n, 1/i) ) 4.000000
A lo cual no le puedo encontrar sentido
Alguien me puede remarcar dónde está fallando? porque llevo un buen rato y hasta cambié floor por ceil y me redondea a 6.000000 sólo en ese caso también
Saludos