SoloCodigo
Programación General => C/C++ => Mensaje iniciado por: Gnu en Miércoles 21 de Abril de 2010, 21:54
-
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
-
Buenas.
Es curioso el problema, y no se porque se produce :ph34r: , pero podes solucionarlo de esta manera:
int espot(float n){
float i = 2, j;
while(i < n){
j = pow(n, 1/i);
if ( j == floor( j) ) )
return 1;
i++;
}
return 0;
}
Saludos
-
Sí, ahí se arregla. A vos también te dio el mismo problema?
Gracias por responder
Saludos