elhacker.net cabecera Bienvenido(a), Visitante. Por favor Ingresar o Registrarse
¿Perdiste tu email de activación?.

 

 


Tema destacado: Curso de javascript por TickTack


  Mostrar Mensajes
Páginas: [1]
1  Programación / Java / Re: invertir un número con recursividad en java en: 12 Marzo 2017, 22:55 pm
(num%10)+(invertir(num/10)*10)
Suponte que num es 123.
(123%10) + invertir(123/10) * 10
Pasaría a:
3 + invertir(12) * 10

Supongamso que invertir funcionase correctamente (que lo hará cuando esté corregida):
3 + 21*10
3 + 210
213

Tú no quieres sumarle 3.
Tú buscas esto:
3*10^3 + 21 (sin el *10)
300 + 21
321

10^3. Ese 3 es el número de cifras del número inicial, 123.

entiendo, con lo que me dices he hecho esto para sacar los dígitos de los números:

Código:
	public static int contar(int num){

int p=1;
do{
num=num/10;
p=p*10;

}while (num!=0);
return p/10;
}

y así el programa funciona correctamente, muchas gracias
2  Programación / Java / Re: invertir un número con recursividad en java en: 12 Marzo 2017, 20:27 pm
En vez de sumar solo num%10, deberías sumarlo multiplicado por 10^N, donde N sería la cantidad de dígitos del número (para colocar la cifra al final).


no entiendo muy bien que quieres decir con eso, puedes ponerme un ejemplo?
3  Programación / Java / Re: en: 12 Marzo 2017, 10:53 am
Efectivamente la lógica de lo que intentas hacer esta correcta solo que al momento de retornar el valor de la función estás considerando que se hace una concatenación de los valores más sin embargo así tal como está tu código se realiza una suma, por eso es que te regresa 6 que es 3+2+1, no estoy muy empapado de java pero puedes intentar convertir a string la operación del (num%10)


¿No sería mejor convertir en String el numero y hacerle el inverso?

Enviado desde mi MotoG3 mediante Tapatalk

Muchas gracias, pero el ejercicio no puedo pasarlo a string, tengo que operar con números enteros, al ejecutar el programa en vez de invertirme los números me los saca de la misma forma, es decir, introduzco 123 y saca 123
4  Programación / Java / invertir un número con recursividad en java en: 11 Marzo 2017, 22:48 pm
Quiero invertir un número con recursividad y no consigo hacerlo, en mi cabeza tiene sentido lo que escribo, pero después al ejecutarlo no se invierte el número, alguien puede decirme donde está el error?

Código:
	public static int invertir(int num) {
if (num<10) {       
  return num;
}
else {

  return (num%10)+(invertir(num/10)*10);
}
}


public static void main(String[] args){
int num=123;
System.out.println(invertir(num));
}
Páginas: [1]
WAP2 - Aviso Legal - Powered by SMF 1.1.21 | SMF © 2006-2008, Simple Machines