Veamos la solución al ejercicio para implementar el algoritmo que determine si un número entero es narcisista utilizando el lenguaje de programación Java.
La explicación del algoritmo así como otras cosas relacionadas al mismo ya las he explicado en este post.
Para reutilizar el código, separar la lógica y seguir buenas prácticas de programación ponemos todo el procedimiento en una función que recibe un número entero (del cual comprobaremos si es o no narcisista) y devuelve un booleano indicando lo anterior.
La función queda así:
private static boolean esNarcisista(int numero){
String numeroComoCadena = Integer.toString(numero);
int longitudDeNumero = numeroComoCadena.length();
double suma = 0;
for(int indice = 0; indice < longitudDeNumero; indice++){
// Convertir carácter a entero
int cifra = Character.getNumericValue(numeroComoCadena.charAt(indice));
/*
Elevarlo al exponente dado por la longitud del número
*/ double elevado = Math.pow(cifra, longitudDeNumero);
// Vamos sumando el resultado
suma = suma + elevado;
}
// Finalmente comprobamos si el número es igual a la suma
if(suma == numero){
return true;
}else{
return false;
}
}
Notamos que para convertir un carácter a un entero utilizamos Character.getNumericValue
.
Para elevar un número a una potencia llamamos a Math.pow
y finalmente (aunque eso pasa primero) usamos Integer.toString
para convertir un entero a una cadena.
Por si no sabemos cómo llamar a la función he escrito este código que llama a la función por cada elemento que hay en un arreglo.
El código de ejemplo completo queda así:
class Narcisista{
public static void main(String[] argumentos){
int numeros[] = {1, 2, 3, 4, 153, 28, 11, 96, 407, 1634, 54748};
for(int numero: numeros){
System.out.println(numero + " es narcisista?" + esNarcisista(numero));
}
}
private static boolean esNarcisista(int numero){
String numeroComoCadena = Integer.toString(numero);
int longitudDeNumero = numeroComoCadena.length();
double suma = 0;
for(int indice = 0; indice < longitudDeNumero; indice++){
// Convertir carácter a entero
int cifra = Character.getNumericValue(numeroComoCadena.charAt(indice));
/*
Elevarlo al exponente dado por la longitud del número
*/ double elevado = Math.pow(cifra, longitudDeNumero);
// Vamos sumando el resultado
suma = suma + elevado;
}
// Finalmente comprobamos si el número es igual a la suma
if(suma == numero){
return true;
}else{
return false;
}
}
}
Cuando lo compilamos y ejecutamos este es el resultado:
En este post te quiero compartir mi experiencia tramitando un acta de nacimiento de México…
Hoy te voy a presentar un creador de credenciales que acabo de programar y que…
Ya te enseñé cómo convertir una aplicación web de Vue 3 en una PWA. Al…
En este artículo voy a documentar la arquitectura que yo utilizo al trabajar con WebAssembly…
En un artículo anterior te enseñé a crear un PWA. Al final, cualquier aplicación que…
Al usar Comlink para trabajar con los workers usando JavaScript me han aparecido algunos errores…
Esta web usa cookies.
Ver comentarios